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INTRODUCTION 

ADVANCED DIGITAL CORPORATION is proud to introduce the SUPER QUAD. 
The SUPER QUAD is a Z80 based single board computer designed to be 
a bus master in an S100 bus system. The SUPER QUAD SBC has all the 
hardware needed to run a single user CP/M system or 2 user MP/M 
system with up to 4 external floppy disk drives and an external 
Centronics parallel interface printer all on one board. 
The board also runs with TURBO-DOS tm. 
The SUPER QUAD SBC contains: 

1) Z-80A cpu (4 MHZ) 

2) Floppy disk controller (up to 4 drives 8" or 5V) 

3) 64K of dynamic memory (16K bank selectible) 

4) 2K or 4K of shadow eprom (2716 or 2732) 

5) 2 serial ports (Z80A SIO opt. syncronous) 

6) 2 12 bit parallel ports, (Z80A PIO) 
one of which can be used 

for S100 vectored interrupts 

7) Real time interrupt clock (Z80A CTC) 

8) S100 extended address A16-A23 

ONE YEAR WARRANTY. 



*Note: Items 5 and 6 require external adaptation for RS-232 and 
Centronics. The adapter boards are 2x2" and are called 
PS NET. They hoop up to the back of the main frame with 
a DB-25 connector. 
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1.1 The Floppy Disk Controller 

The floppy disk controller can access up to four 8 inch or 5.25 
inch floppy disk drives. It can read and write IBM 3740 single 
density format and double density 128,256,512,1024 sector size 
formats. Data transfer is done by programmed I/O with wait and 
interrupt syncronization. 

Note : The controller cannot access both 8 inch and 5.25 inch drives 
simultaniously,The controller is switched from 8 inch to 5.25 inch 
drives by hardware jumper options. 

1.2 The 64 k Dynamic ram 



The 64 k ram array can be switched on and off in 16 k increments 
(0-16K,16K-32K,32K-48K,48K-64K) under software control. This allows the 
CPU to access bank switchable external memory on the S100 bus. 
The memory has an access time of 200ns. Refresh is done during 
Z80 Ml cycles and during wait and reset states. The memory can 
be accessed by an external DMA device on the S100 bus. 
Note : Any external DMA device that is using continous mode DMA 
cycles must transfer data at an average rate of 15 us per byte or 
faster when holding the DMA request line for more than 1.5 ms This is 
not a problem because most designers are smart enough to use 
byte-at-a-time or burst transfer modes when dealing with slow DMA 
transfer rates. The ram row address is the low order address there- 
for the entire ram array is refreshed by the DMA device every 128 
contiguous memory cycles. 



1.3 System Monitor Eprom 

The system monitor eprom is switched on during reset. It can be 

disabled and enabled under software control. It resides when 

enabled at F000h to FFFFh. It has commands that allow the user 

to load the CP/M , MP/M or other boot loaders from floppy disk. 

In addition it can be used to load , examine goto and test 

memory. When the prom is disabled, it does not use any system address 

space. 

1 .4 Serial ports 

A Z80A DART is used for the two serial ports , but 

a Z80A SIO/0 chip can be used in it's place. This allows 

asyncronous and synchronous serial data communications plus a variety 

of interrupt modes. Modem control signals are available at each 

serial connector. There are two switch selectible baud rate 

generators for baud rates of 50 to 19.2 k baud. 

Note : The serial ports are TTL and must be connected to external 

interface boards for RS232 communications. 

(PS NET/I) 

1.5 Parallel ports 



A Z80A PIO is used as the parallel port. The "A" channel of this chip 
is connected to the parallel port connector. This port has 8 bi-dir- 
ectional data lines and two hand shake lines. The "B" port can be split 
between the parallel port connector and the S100 bus vectored interrupt 
lines by jumper options. This allows the port to be used as an 
additional parallel port or interrupt controller or both. 
In the output mode the parallel ports can drive one TTL load . 



1.6 Real Time Interrupt clock 

A Z80A CTC is used for providing a real time system clock for MP/M. 
Three channels of the CTC are available to the user for strapping via 
a jumper header for synchronous baud rates or long clock times. 

1.7 S100 Bus Interface 



The S100 bus interface provides the signals necessary for an 8 bit 
bus master as described by the IEEE 696 bus specification. 
Vectored interrupt lines VI0 - V17 are supported via jumper options 
and A16 - A23 are also supported vis an I/O port. 
The PAMNTON line is also implemented for the dynamic ram array. 



2.0 EPROM and Monitor operation 

The onboard EPROM occupies address F000H-FFFFH. The EPROM 
is switched on automatically during reset or power on, the 
EPROM contains SIO and FDC initialization code along with a 
simple debugger and floppy disk cold start loader. After 
the operating system is loaded the EPROM can be turned off 
so that the ram at address F000H-FFFFH can be accessed. The 
EPROM can be turned on and off at any time so that hardware 
dependent I/O routines can be called. 

2.1 Eprom Enable / Disable 

Switching EPROM on : 

F033 3E4F MVI A r 01001111B ;RESET POWER ON JUMP 

; AND ENABLE MEMORY, EPROM ON 
F035 D316 OUT 16H ; WRITE TO CONTROL PORT 

Switching EPROM off : 

F033 3E4F MVI A,01101111B ;RESET POWER ON JUMP 

; AND ENABLE MEMORY, EPROM OFF 
F035 D316 OUT 16H ;WRITE TO CONTROL PORT 

Jumper R configures the board to accept a 2716 or 2732 EPROM. 
Note : The EPROM is always addressed at F800H and can not 
be moved. Since the 2716 EPROM is 2K long it appears 
twice , F800H-FC00H and FBFFH-FEFFH. 

2.2 Monitor Signon 

The EPROM contains a simple debugger. 
The monitor signs on with : 

> ADVANCED DIGITAL CORP. 

Monitor Version 1.1 

Mar - 1982 

Press "H" for help 
> 

2.3 Monitor Commands 



The monitor commands are : 

Control B = Load disk boot loader 5.25" 

Control C = Load disk boot loader 8 " 

D SSSS QQQQ = Dump memory in hex from SSSS to QQQQ 

F SSSS QQQQ BB = Fill memory from SSSS to QQQQ with BB 

G AAAA = Go to address AAAA 

L AAAA = Load memory starting at AAAA 

M SSSS QQQQ DD = Move from S to Q to ADDR DD 

P SSSS QQQQ = Print in ascii from SSSS to QQQQ 

T = Test Memory 

ESC will terminate any command 



The cold boot loader will select and home drive 0. 

Track sector 1 will be read into memory at location 0. 

Single density is assumed for track 0. 

If an error occures an error code will be printed. 

The error code must be translated using the table 

in appendex F page F-4 fig 2. 

e.g. FDC COLD BOOT ERROR 80= DISK NOT DETECTED 

FDC COLD BOOT ERROR 10= WRONG FORMAT OR NO DATA ON DISK OR BAD PHASE LOC 

LOOP. 

2.4 Cold Boot Program 

; READ TRACK SECTOR 1 INTO MEMORY 



;set double for 5 inch 

; RESET FDC 

; ISSUE COMMAND 







BOOT 5: 


MVI 
OUT 


A,08H 
WAIT 






BOOT: 






F4B5 


3E0D 




MVI 


A,0DH 


F4B7 


D30C 




OUT 


FDC 


F4B9 


00 


FDCW1 : 


NOP 




F4BA 


DB0C 


* 


IN 


FDC 


F4BC 


0F 




RRC 




F4BD 


DABAF4 




JC 


FDCW1 


F4C0 


00 




NOP 





; CHECK BUSY. 



; KILL TIME 



F4C1 00 
F4C2 00 



NOP 
NOP 



F4C3 00 



NOP 



F4C4 


3E03 


MVI 


A, 3 


F4C6 


D30C 


OUT 


FDC 


F4C8 


00 


NOP 




F4C9 


DB14 


IN 


WAIT 


F4CB 


00 


NOP 
TK0 : 




F4CC 


DB0C 


IN 


FDC 


F4CE 


E604 


AN I 


4 


F4D0 


CACCF4 


JZ 


TK0 


F4D3 


AF 


XRA 


A 


F4D4 


6F 


MOV 


L,A 


F4D5 


67 


MOV 


H r A 


F4D6 


3C 


INR 


A 


F4D7 


D30E 


OUT 


FDCSEC 


F4D9 


3E8C 


MVI 


A,08CH 


F4DB 


D30C 


OUT 


FDC 


F4DD 


00 


NOP 
FDCRD: 




F4DE 


DB14 


IN 


WAIT 


F4E0 


B7 


ORA 


A 


F4E1 


F2EBF4 


JP 


BOOTDN 


F4E4 


DB0F 


IN 


FDCDATA 


F4E6 


77 


MOV 


M,A 


F4E7 


23 


INX 


H 


F4E8 


C3DEF4 


JMP 
BOOTDN : 


FDCRD 


F4EB 


DB0C 


IN 


FDC 


F4ED 


B7 


ORA 


A 


F4EE 


CA0000 


JZ 





F4F1 


F5 


PUSH 


PSW 


F4F2 


210FF6 


LXI 


R,BTERR 


F4F5 


CDE6F0 


CALL 


MSG 


F4F8 


Fl 


POP 


PSW 


F4F9 


CD21F1 


CALL 


THXB 



; GET A RESTORE 
; ISSUE COMMAND 



; WAIT FOR 
; INTRQ 



; CHECK TRACK 



POINT AT LOC 



SET SECTOR 

GET READ COMMAND 

ISSUE COMMAND 



WAIT FOR INTRQ 

OR DRQ 
EXIT IF INTRQ 
GET DATA 
STORE 
POINT NEXT 



CHECK STATUS 
= NO ERROR 
OK r GO 
SAVE ERROR 
PRINT 

DISK ERROR 
GET ERROR 
PRINT IT 



3.0 



INPUT / OUTPUT PORT ASS1GMENTS 
Address Function 



00 


Read/Write 


SIO 


Channel 


A 


Data port 




01 


Read/Write 


SIO 


Channel 


A 


Status/Control 


Port 


02 


Read/Write 


SIO 


Channel 


B 


Data port 




03 


Read/Wr ite 


SIO 


Channel 


B 


Status/Control 


Port 


04 


Read/Write 


PIO 


Channel 


A 


Data port 




05 


Read/Write 


PIO 


Channel 


B 


Data port 




06 


Write 


PIO 


Channel 


A 


Control port 




07 


Write 


PIO 


Channel 


B 


Control Port 




08 


Read/Wr ite 


CTC 


Channel 





Control Port 




09 


Read/Wr ite 


CTC 


Channel 


1 


Control Portol 




0A 


Read/Write 


CTC 


Channel 


2 


Control Port 




0B 


Read/Write 


CTC 


Channel 


3 


Control Port 




0C 


Read/Write 


FDC 


Command/States Port 




0D 


Read/Write 


FDC 


Track Register 




0E 


Read/Write 


FDC 


Sector Register 




0F 


Read/Wr ite 


FDC 


Data Port 






10 




Unused 








11 




Unused 








12 




Unused 








13 




Unused 








14 


Read/Write 


FDC 


Syncronization/Dr ive/Densi ty 


15 


Write 


S10C 


3 Buss Extended Address A16-A24 


16 


Write 


On-Board Memoi 


:y Control Port 




17 




Unused 








18 




Unused 








19 




Unused 








1A 




Unused 








IB 




Unused 








1C 




Unused 








ID 




Unused 








IE 




Unused 








IF 




Unused 









All addresses are listed in Hexidecimal. 

The unused input / output ports are internally decoded and 

should not be used by external S100 I/O boards. 
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4.0 INPUT / OUTPUT PORT DISCRETIONS 

4.1 Serial Communications Port A — - See Appendix A 

00 Read/Write SIO Channel A Data poet 

01 Read/Write SIO Channel A Status/Control Port 

4.2 Serial Communications Port B See Appendex A 

02 Read/Write SIO Channel B Data port 

03 Read/Write SIO Channel B Status/Control Pott 

4.3 Paralled Interface Pott A See Appendix B 

04 Read/Write PIO Channel A Data port 

06 Write PIO Channel A Control Pott 

4.4 Parallel Interface Port B See Appendix B 

This port can be jumpered via jumpers E through P to the 

S100 Vectored Interrupt lines or to connector J2 (see sec 6.0 ) 

05 Read/Write PIO Channel B Data port 

07 Write PIO Channel B Control Pott 

4.5 Control Tiiumer Interrupt circuit See Appendix C 

08 Read/Write CTC Channel Control Pott 

09 Read/Write CTC Channel 1 Control Pott 
0A Read/Write CTC Channel 2 Control Pott 
0B Read/Write CTC Channel 3 Control Pott 

4.6 Floppy Disk Controller See Appendix D 

0C Read/Write FDC Command/States Port 

0D Read/Write FDC Track Register 

0E Read/Write FDC Sector Register 

0F Read/Write FDC Data Port 
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4.7 Floppy Disk Control Port 

14 Read/Write FDC Syncronization/Dr ive/Densi ty 

Port Read : 
CC 

When the cpu reads this port the cpu is placed into a wait 

state until a data byte can be transfered to or from the floppy 

disk controller or untill the command complete/terminate status 

(INTRQ) is set by the floppy disk controller. The floppy disk 

controller INTRQ status bit is placed on the data bus as bit D7 . 

This bit can be tested to determine if data is to be transfered 

of if the command is complete. 

I D7 i D6 i D5 I D4 i D3 1 D2 1 Dl ! DO I D7 = MSB, D0 = LSB 

1 I I I I I I I 

I I I 1 I ! ! + — Don 1 t care 

I 1 I 1 I 1 + Don't care 

1 i « l l + Don't care 

1 it j + Don't care 

i i + Don't care 

I + ■ Don't care 

+ Don't care 

+ INTRQ* 0=active, l=inactive 

Port Write : 

The low two bits D0 and Dl of this port control which drive is 

selected. 



Dl D0 












1 


1 





1 


1 



Disk drive selected 
Disk drive 1 selected 
Disk drive 2 selected 
Disk drive 3 selected 
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Bit D3 sets the density mode. When bit D3 = 0, single density is 



selected. When bit D3 = 1 , double density is selected. 



+ +^ + + + + + + + 

! D7 ! D6 i D5 ! D4 ! D3 ! D2 i Dl 1 DO ! 
+ + + + + + + + + 



D7 = MSB, D0 = LSB 



i » 

i + — Disk drive select bit D0 
+ Disk drive select bit Dl 

SIDE SELECT, 0=HEAD 0,1=HEAD 1 

Density, 0=single, l=double 

Don't care 

Don't care 

Don't care 

Don't care 



4.8 Extended address port See Section 8.1 (buss defination) 

15 Write S100 Buss Extended Address A16-A23 

Port Write : 



This port controls the S100 Extended address lines. 

D7 = MSB, D0 = LSB 



+ + +. + + + — — .+ + + 

! D7 1 D6 ! D5 ! D4 ! D3 ! D2 I Dl ! DO i 
+ + + + + +_ — -+ + + 



+- 



i 

+ — A16 

A17 

A18 

A19 

A20 

A21 

A22 

A23 
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4.9 On-Board Memory Control Port 

16 Write On-Board Memory Control port 

This port controls the onboard memory managment circuit, 

Prom enable and disable and power on jump reset circuits. 

Port write : 

The four low order bits D0,D1,D2 and D3 switch the on board memory 

in 16k banks corresponding to address 0000h-3FFFh,4000H-7FFFH, 

8000H-BFFFB and C000-FFFFH on and off. When a particular bank is 

switched off, external S100 memory can be accessed in that 

banks address range. This feature allows external memory to be 

added to the system for multi-user operating systems. 

Bit D5 of this port switches the on-board EPROM on and off. 

The onboard EPROM occupies address F000H-FFFFH. The EPROM 

is switched on automatically during reset or power on, the 

EPROM contains SIO and FDC initialization code along with a 

simple debugger and floppy disk cold start loader. After 

the operating system is loaded the EPROM can be turned off 

so that the ram at address F000H-FFFFH can be accessed. 

Bit D6 reset the power on jump circuit. Bit D6 must be set 

high after a reset or power on situation before ram can 

be accessed. 



+ + + + f. + 1- + + 

! D7 i D6 I D5 i D4 ! D3 ! D2 ! Dl i DO i 
+ + + \. + + + + + 



D7 = MSB, D0 = LSB 



i 



! 



1 • l=bank on, 0=bank .off 
! + — Memory Bank 0000H-3FFFH 

+ Memory Bank 4000H-7FFFH 

Memory Bank 8000H-BFFFH 

Menory Bank C000H-FFFFH 



i 

i i 

i i 

! ! 

1 I 

« i i + Don't care 

! i + PROM enable=0, Disable=l 

i ^ power on jump reset=l 

+ Don't care 
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5.0 Jumper Definitions 

Jumper Function 

A CPU clock tate 2mhz/4mhz 

B Lxtemal/Enternal Tx/Rx clock for SIO channel A 

C Extemal/Enternal Tx/Rx clock foi SIO channel B 

D Eight inch - five inch Drive selection 

E Select S100 interrupt vector line V10 OR PINT. 

P Select S100 interrupt vector VIO/PINT or Parallel 

Port B bit D0 on J2-25. 
N Select S100 interrupt vector VII or Parallel 

Port B bit Dl on J2-27. 
M Select S100 interrupt vector VI2 or Parallel 

Port B bit D2 on J2-29. 
K Select S1G0 interrupt vector VI3 or Parallel 

Port B bit D3 on J2-31. 
J Select S100 interrupt vector V14 or Parallel 

Port B bit D4 on J2-33. 
H Select S100 interrupt vector VI5 or Parallel 

Port B bit D5 on J2-35. 
G Select S100 interrupt vector VI6 or Parallel 

Port B bit D6 on J2-37. 
F Select S100 interrupt vector VI7 or Parallel 

Port B bit D7 on J2-39. 
R Select 2716 or 2732 EPROM. 
S Define floppy disk connector for eight ad five inch 

dr ives. 
T Enable / Disable S100 bus memory write signal on 

Jl - 68 

6.0 Jumper Descriptions 

6.1 A CPU clock tate 2mhz/4mhz 
This jumper determines the cpu clock rate. 
The jumper is located below IC U7 . 

+ t-i-4 + 

1112 13 1 

+ h j- + 

Install Plug between posts 1 & 2 for 4mhz operation. 
Install Plug between posts 2 & 3 for 2mhz operation. 

6.2 B External/ internal Tx/Rx clock for SIO channel A 
Jumper B connects the SIO channel A to either the internal baud rate 
generator or to the connector J# pin 9 for use in sycronous applications 
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Jumper B is located near J5. 

+ + 

I 1 1 

+ + 

r ! 2 ! 

+ + 

U> 3 ! 

+ + 

Install Plug between posts 1 & 2 for external SIO clock. 



Connector J5 pin 9 

SIO Tx/Rx clock input 

Baud rate generator channel A 



Install Plug between posts 2 & 3 for Baud rate generator . 

6.3 C External/internal Tx/Rx clock for SIO channel B 

Jumper C connects the SIO channel B to either the internal baud rate 

generator or to connector J5 pin 9 for use in sycronous applications. 

Jumper C is located near J5. 

+ + 

! 1 ! Connector J5 pin 9 

+ + 

! 2 ! SIO Tx/Rx clock input 

+ + 

! 3 1 Baud rate generator channel B 

+ + 

Install Plug between posts 1 & 2 for external SIO clock. 

Install Plug between posts 2 & 3 for Baud rate generator . 

6.4 D Eight inch - five inch Drive selection 
Jumper D is located near IC U2. 



+ + 

• 6 i 

+ + 

! 5 1 

+ + 

! 4 ! 
+ + 

1 3 i 
+ + 

i 2 ! 
+ + 

I 1 I 



8 inch floppy clock source 

FDC clock input 

5.25 inch floppy clock source 

5.25 head load/motor 

Head load source 

8 inch head load 



+ + 

Install Plug between posts 1 & 2 and 5 & 6 for 8 drives. 

Install Plug between posts 2 & 3 and 4 & 5 for 5.25 inch drives 
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Note : There aie other board modi locations needed to interface 
the FDC to a 5.25 inch drive. 

6.5 E Select S100 interrupt vector line VI0 OR PINT. 
Jumper E selects the interrupt line to be used when channel B 
bit D0 is programmed for interrupts. 

Jumper E is located below IC U8. 

+ _I_.f_l_ + + 

•112 13! 
+ + + + 

Install Plug between posts 1 & 2 for VI0 interrupt pin. (Jl-4) 
Install Plug between posts 2 & 3 for PINT interrupt pin. (Jl-73) 

6.6 y V- Select S100 interrupt vector VIO/PINT or Parallel 

Port B bit D0 on J2-25. 

This jumper is located near connector J2. 

+ + — C--tF_T__ + 

I 1 ! 2 1 3 ! 
+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit D0 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 fc 3 to connect the PIO bit D0 

to the jumper selector area E, VI0/P1NT (when the PIO bit is 

programmed for interrupt mode). 

6.7 X§ Select S100 interrupt vector Vll or Parallel 

Port B bit Dl on J2-27 . 

This jumper is located near connector J2. 

+ + — rz%1 — + 

11*2131 

+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit Dl 

to J2 pin 25 (when the PIO bit is programmed for input/output). 

Install Plug between posts 2 & 3 to connect the PIO bit Dl 

to the vectored interrupt line VII (when the PIO bit is 

programmed for interrupt mode). 
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6.8 JMftf Select S100 interrupt vector VI2 or parallel 

Port B bit D2 on J2-29. 
This jumper is located near connector J2. 

+ + — c£.n._+ 

1112 13 1 

+ + + + 

Install Plug between posts 1 & 2 to connect the PIO bit D2 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D2 
to the vectored interrupt line VI2 (when the PIO bit is 
programmed for interrupt mode) . 

6.9 X J Select S100 interrupt vector VI3 or Parallel 

Port B bit D3 on J2-31. 
This jumper is located near connector J2. 

1112 13 1 
+ + + + 

Install Plug between posts -1 & 2 to connect the PIO bit D3 

to 32 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D3 
to the vectored interrupt line VI3 (when the PIO bit is 
programmed for interrupt mode) . 

6.10 jS l< Select S100 interrupt vector VI4 ot Parallel 

Port B bit D4 on J2-33. 
This jumper is located near connector J2 . 

+ +—TL£rL_+ 

1112 13 1 

+ ^ + + 

Install Plug between posts 1 & 2 to connect the PIO bit D4 
to J2 pin 25 (when the PIO bit is programmed for input/output) . 
Install Plug between posts 2 & 3 to connect the PIO bit D4 
to the vectored interrupt linr VI4 (when the PIO bit is 
programmed for interrupt mode). 

6.11 /tfM Select S100 interrupt vector VI5 or Parallel 

Port B bit D5 on J2-35. 
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This jumper is located near connector J2. 

+ + ^ 4. 

1112 13 1 

+ 1- + + 

Install Plug between posts 1 & 2 to connect the PIO bit D5 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

• 

Install Plug between posts 2 & 3 to connect the PIO bit D5 

to the vectored interrupt line V15 (when the PIO bit is 
programmed for interrupt mode). 

6.12 Z N Select S100 interrupt vector VI6 or Parallel 

Port B bit D6 on J2-37. 
This jumper is located near connector J2. 

+ + — '_+_> — + 

1112 13 1 
^ f. + + 

Install Plug between posts 1 & 2 to connect the PIO bit D6 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D6 

to the vectored interrupt line VI6 (when the PIO bit is 

programmed for interrupt mode). 

6.13 p Select S100 interrupt vector VI7 or Parallel 

Port B bit D7 on J 2- 39. 

This jumper is located near connector 32. 

1112 13 1 
+ f h + 

Install Plug between posts 1 & 2 to connect the PIO bit D7 

to J2 pin 25 (when the PIO bit is programmed for input/output) . 

Install Plug between posts 2 & 3 to connect the PIO bit D7 
to the vectored interrupt line VI7 (when the PIO bit is 
programmed for interrupt mode). 

6.14 R Select 2716 or 2732 EPROM . 
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Jumper R configures the board to accept a 2716 or 2732 EPROM 
Jumper R is located near the Z80 chip. 



+ + 

! 1 ! 
4 + 

1 2 I 

+ + 

13! 
+ + 

Install Plug between posts 1 & 2 for a 2732 EPROM. 



Address line All 
EPROM input 
+5 volts 



Install Plug between posts 2 & 3 for a 2716 EPROM. 

Note : The EPROM is always addressed at F800H and can not 

be moved. Since the 2716 EPROM is 2K long it appears 
twice , E800H-FC00H and FBFFH-FFFFR. 



6.15 



Define floppy disk connector for eight , five inch 
drives and FDC chip type. 



This jumper is located U26. j [ 

+ + + + 



i 1 
+- — 
! 4 



+-- 



I 7 



2 ! 3 ! 

1- + 

5 16! 



+ 4-__ l <Hn^._4. 



8 ! 9 ! 



+ _Jrrq^n._4- + 



11! 12! 



! 10 

+ + + + 

For 8" set-up plug the following jumpers: 
lto4 ,2to3 ,5to6 ,7to8 . 

For 5 1/4" plug the following jumpers: 

lto2 , 5to8 ,6to9 ,7tol0 , llto!2 . (see factory installed jumpers for 

additional jumpers or changes.) 



20 



6.16 T Enable / Disable S100 bus memory write signal on 

Jl - 68 
This jumper is located near U18 . 

+ — •'-+---+ 
1112 1 
+ + + 

Install Plug between posts 1 & 2 to connect the memory write 

signal (MEMWR) to the S100 bus pin 68. 

7.0 Baud Rate Switch 



The baud rate of the two serial channels can be select separately 
by setting the baud rate switch. The baud rate switch is an 8 
pole switch located near U54. It is split into two sections. 
Switches 1,2,3,4 set the baud rate for the SIO channel B and 
switches 5,6,7,8 set the baud rate for the SIO channel A. 



+ + OFF (up) 

SW1 18171615141312111 

+ + ON (down) 

<- Channel B -> <- Channel A -> 

7.1 Baud rate switch setting 

Switch 8 7 6 5 Channel B baud rate 
Switch 4 3 2 1 Channel A baud rate 

on on on on 50 

offon on on 75 

on off on on 110 

off off on on 134.5 

on on off on 150 

off on off on 300 

on off off on 600 

off off off on 1200 

on on on off 1800 

off on on off 2000 

on off on off 2400 

off off on off 3600 

on on off off 4800 

off on off off 7200 

on off off off 9600 

off off off off 19,200 
For exact baud rate frequencies see Appendix D 
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8.0 



External Connector Pin definitions 



8.1 



Connector Jl - S100 bus connector 



PIN# 



NAME 



PIN # 



NAME 



1 


+8V 


51 


+8V 


2 


+ 16V 


52 


-16V 


3 


XRDY 


53 


GND 


4 


VI 0* 


54 


SLAVE CLR* 


5 


Vll* 


55-57 


DMA0*-DMA2* 


6 


VI 2* 


58 


SXTRQ* 


7 


VI3* 


59 


A19 


8 


VI4* 


60 


SIXTN* 


9 


VI5* 


61-64 


A20-A23 


10 


VI6* 


65,65 


NDEF 


11 


VI7* 


67 


PHANTOM* 


12 


NMI* 


68 


MWRT 


13 


PWRFAIL* 


69 


RFU 


14 


DMA3* 


70 


GND 


15 


A18 


71 


RFU 


16 


A17 


72 


RDY 


17 


A16 


7 3 


INT* 


18 


SDSB* 


74 


HOLD* 


19 


CDSB* 


75 


RESET* 


20 


GND 


76 


PSYNCH 


21 


NDEF 


77 


PWR* 


22 


ADSB* 


78 


PDBIN 


23 


DODSB* 


79-87 


A0-A11 


24 





88-95 


DO2-DI0 


25 


PSTVAL* 


96 


SINTA 


26 


PHLDA 


97 


SWO* 


27,28 


RFU 


98 


ERROR* 


29-34 


A5,A4,A3,A15 


,A12,A9 




35 


DO 1 /DATA 1 


99 


POC* 


36 


DO0/DATA 


100 


GND 


37 


A10 






38 


D04 






39 


D05 






40-43 


D06,DI2,DI3, 


DI7 




44 


SMI 






45 


SOUT 






46 


SINP 






47 


SMEMR 






48 


SHLTA 






49 


CLOCK 






50 


GND 
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8.2 Connector J2 - Parallel port connector 



PIO Channel A ready signal 

ground 

PIO Channel A strobe 

ground 

PIO Channel A data bit D0 

ground 

PIO Channel A data bit Dl 

ground 

PIO Channel A data bit D2 

ground 

PIO Channel A data bit D3 

ground 

PIO Channel A data bit D4 

ground 

PIO Channel A data bit D5 

ground 

PIO Channel A data bit D6 

ground 

PIO Channel A data bit D7 

ground 

PIO Channel B ready signal 

ground 

PIO Channel B strobe 

ground 

PIO Channel B data bit D0 

ground 

PIO Channel B data bit Dl 

ground 

PIO Channel B data bit D2 

ground 

PIO Channel B data bit D3 

ground 

PIO Channel B data bit D4 

ground 

PIO Channel B data bit D5 

ground 

PIO Channel B data bit D6 

ground 

PIO Channel B data bit D7 



* Mote : These pins can can be jumpered to the S100 bus 
vectored interrupt lines. 



1 


ARDY 


2 


ARD^ 


: RET 


3 


ASTRB* 


4 


ASTRB RET 


5 


PA0 




6 


PA0 


RET 


7 


PA1 




8 


PA1 


RET 


9 


PA2 




10 


PA2 


RET 


11 


PA3 




12 


PA3 


RET 


13 


PA4 




14 


PA4 


RET 


15 


PAS 




16 


PA5 


RET 


17 


PA6 




18 


PA6 


RET 


19 


PA7 




20 


PA7 


RET 


21 


BRDY 


22 


BRDY RET 


23 


BSTRB* 


24 


BSTRB RET 


25 


PB0 




26 


PB0 


RET 


27 


PB1 




28 


PB1 


RET 


29 


PB2 




30 


PB2 


RET 


31 


PB3 




32 


PB3 


RET 


33 


PB4 




34 


PB4 


RET 


35 


PB5 




36 


PB5 


RET 


37 


PB6 




38 


PB6 


RET 


39 


PB7 




40 


+ 5 


VOLTS 



23 



8.3 Connector J3 E'loppy disk connector 

8 inch 5.25 inch 



1 




2 




3 




4 




5 




6 




7 




8 




9 




10 




11 




12 




13 




14 




15 




16 




17 


1 


18 


2 


19 


3 


20 


4 


21 


5 


22 


6 


23 


7 


24 


8 


25 


9 


26 


10 


27 


11 


28 


12 


29 


13 


30 


14 


31 


15 


3 2 


16 


33 


17 


34 


18 


35 


19 


36 


20 


37 


21 


38 


22 


39 


23 


40 


24 


41 


25 


42 


26 


43 


27 


44 


28 


45 


29 


45 


30 


47 


31 


48 


32 


49 


33 


50 


34 



ground 

Alternate Head 2* 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

N/C 

ground 

Head 2* 

ground 

N/C 

ground 

Head load* 

ground 

Index* 

ground 

Ready* 

ground 

Above Track 43* 

ground 

Drive select 0* 

ground 

Drive select 1* 

ground 

Drive select 2* 

ground 

Drive select 3* 

ground 

Direction 

ground 

Step* 

ground 

Write Data* 

ground 

Write gate* 

ground 

Track 0* 

ground 

Write protect* 

ground 

Read data* 

ground 

Motor on* 

ground 

N/C 
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8.5 



Connector 


J4 


1 


N/C 


2 


DCDA* 


3 


SYNCA* 


4 


RxDA 


5 


CTSA* 


6 


TxDA 


7 


RTSA* 


8 


DTRA* 


9 


Tx/RxCA* 


10 


GND 


11 


N/C 


12 


+16 VOLTS 


13 


-16 VOLTS 


14 


+5 VOLTS 


Connector 


J5 


1 


N/C 


2 


DCDA* 


3 


SYNCA* 


4 


RxDA 


5 


CTSA* 


6 


TXDA 


7 


RTSA* 


8 


DTRA* 


9 


Tx/RxCA* 


10 


GND 


11 


N/C 


12 


+16 VOLTS 


13 


-16 VOLTS 


14 


+5 VOLTS 



Serial port Channel A 



Data Carrer Detect Channel 
Sync Detect 
Receive data 
Clear to send 
Transmit data 
Request to send 
Data terminal ready 
Transmitt / receive clock 



Serial port Channel B 



Data Carrer Detect Channel 
Sync Detect 
Receive data 
Clear to send 
Transmit data 
Request to send 
Data terminal ready 
Transmitt / receive clock 



25 



+ ■ 

1 

+• 



+ 

connector i 

i i 

I + 

i i 

■+ +■ — + 

Parallel 1 
ports 1 

i 



+ + 

-+ jumpers! 
+ — + + 



1 connecto 

i 
i 



f 

r ! 
+ 



i 

-t 

i 
I 
+ 

clock 1 

i 

+ 



+ + __ + 

l Floppy disk! 
! controller! 



■+■ 



+-+ 



+ + — + 

! data rec . ! 

! /drivers ! 

+ h 

i 

i 
i 
■-+ 



+ ■ 
i 

+• 



leproml ! CPU 

!2k,4k+ — + — + 

+ + i + 

i 

[ 

! S100 address i 
! drivers ! 

i 

VI + 

llines ! 

4- \ 

S100 BUS 



+ 

j 



+ + + + 

Iconni !conn! 

+-+— + + — +-+ 
i i 

I i 

! ! 

+_ + +_ + 

! A Serial B i 
! ports ! 

I 
i 

. + 

i 
i 

! Ram Array ! 



i 
t 
I 
i 
i 

+ 



26 



10.0 Factory Installed Jumpers 



10.1 Factory Installed jumpers for 8 inch floppy option 
Jumper 



A 


t-l 


CPU clock 4mhz 






B 


2-3 


Tx/Rx clock for 


SIO A : 


Internal 


C 


2-3 


Tx/Rx clock for 


SIO B : 


internal 


D 


1-2,5-6 


Eight inch Drive selection 


E 


1-2 


Select vector 


1: 


Lne VI0 




F 


2-3 


Parallel Port 


B 


bit D0 


on J2-25 


G 


2-3 


Parallel Port 


B 


bit Dl 


on J2-27 


H 


2-3 


Parallel Port 


B 


bit D2 


on J2-29 


J 


2-3 


Parallel Port 


B 


bit D3 


on J2-31 


K 


2-3 


Parallel Port 


B 


bit D4 


on J2-33 


M 


2-3 


Parallel Port 


B 


bit D5 


on J2-35 


N 


2-3 


Parallel Port 


B 


bit D6 


on J2-37 


P 


2-3 


Parallel Port 


B 


bit D7 


on J2-39 


R 


2-3 


Select 2716 








S 


l,g;2,3;5,6;7,8 


define floppy 


d: 


isk connector 


T 


1-2 


Enable S100 bus 


memory 


write si 



10.2 Factory Installed jumpers for 5.25 inch floppy option 

Jumper 

CPU clock 4mhz 

Tx/Rx clock for SIO A internal 
Tx/Rx clock for SIO B internal 
Eight inch Drive selection 
Select vector line VI0 
Parallel 
Parallel 
Parallel 
Parallel 
Parallel 
Parallel 
Parallel 
Parallel 
Select 2716 
1 ,2; 5 ,8 ; 6 ,9 ; 7 , 10 ; 11 ,12 Define floppy disk connector 

Enable S100 bus memory write signal 

(to convert an 8" board to 5 1/4" the following is required in addi- 
tion to the addendum) 
Capacitor C22 is changed to a 100pf or parallel a 47pf with it. 
Capacitor C6 is changed to a 10mf. 
Resistor R4 is changed to 220k ohm 

Re-adjust the phase lock loop by adjusting the R26 pot. 
An easy way to adjust would be to put one trace of the scope on 
pin 7 of the u27(74sl24) and the other channel on a 2 MHZ. 



A 


2-3 


B 


2-3 


C 


2-3 


D 


1-2,5 


E 


1-2 


F 


2-3 


G 


2-3 


H 


2-3 


J 


2-3 


K 


2-3 


M 


2-3 


N 


2-3 


P 


2-3 


R 


2-1 


S 


1 , 2; 5 ,8 ; 6 , 


T 


1-2 



Port 


B 


bit 


D0 


on 


J2- 


-25 . 


Port 


B 


bit 


Dl 


on 


J2- 


-27. 


Port 


B 


bit 


D2 


on 


J2- 


-29. 


Port 


B 


bit 


D3 


on 


J2- 


-31. 


Port 


B 


bit 


D4 


on 


J2- 


-33. 


Port 


B 


bit 


D5 


on 


J2- 


-35. 


Port 


B 


bit 


D6 


on 


J2- 


-37. 


Port 


B 


bit 


D7 


on 


J2- 


-39. 
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10.3 



Shugart SA 800 Jumpers 



Disk drive jumpers 

Remove all jumpers on the disk drive. Install jumpers as follows 

Jumper Y 
Jumper C 
Jumper T2 
Jumper Tl 
Jumper 800 
Jumper L 
Jumper A 
Jumper B 
Jumper DS 

10.4 Shugart 850 



Disk drive Jumpers 

Jumper 2S 
Jumper C 
Jumper A 
Jumper B 
Jumper R 
Jumper I 
Jumper Y 
Jumper 850 
Jumper S2 
Jumper IT 
Jumper FS 
Jumper RM 
Jumper DS 
Jumper S 
Jumper M 



Jumper FM,MFM 

DS1 for drive 1 and DS2 for drive 

install termination at the end of 



2 
cable 



10.6 MFE Model 700 



Disk drive jumpers 



Install jumpers as follows: 

Jumper Jl-4,Jl-8 

Jumper J10 

Jumper J7 

Jumper SSI 

Jumper SE2 

Jumper Jll r HSl 



C 



Jumper J 3 
Jumper RHL 
Jumper J4 
Jumper L-l 
Jumper J3 
Jumper WP1 
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10.7 TANDON SLIM LINE 
Disk drive jumpers 

Install jumpers as follows: 

DS1 OR DS2 

INSTALL THE TERMINATION RES. AT THE END OF THE CABLE 

10.8 NEC model FD1160 
Disk drive Jumpers 

Install jumpers as follows: 

Jumper C Jumper PRI 

Jumper N Jumper DLD 

Jumper HLS Jumper FU 

Jumper M 

10.9 QUME data track 8 
Disk drive jumpers 

Install jumpers as follows: 

DS1 OR DS2 
CUT X 
CUT Z 
CUT L 
INSTALL Y 
INSTALL C 

10.9.1 TANDON 5 1/4 " DRIVE(48TPI) 

Disk drive jumpers 

Install jumpers as follows: 

On the dip shunt header only pin2,7,8 are on. 

for DS1 and pins3,7,8 for DS2. 
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11.0 Appendex & Data sheets 



11.1 Appendex A - Z80A S10 / DART 
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Z8470Z80®DART 
Dual Asynchronous 
Receiver/Transmitter 




Zilog 



Product 



March 1981 



Features B Two independent full-duplex channels with 

separate modem controls. Modem status can 
be monitored. 

B Receiver data registers are quadruply buf- 
fered; the transmitter is doubly buffered. 

B Interrupt features include a programmable 
interrupt vector, a "status affects vector" 
mode for fast interrupt processing, and the 
standard Z-80 peripheral daisy- chain inter- 
rupt structure that provides automatic inter- 
rupt vectoring with no external logic. 



In xl clock mode, data rates are to 500K 
bits/second with a 2.5 MHz clock, or to 
800K bits/second with a 4.0 MHz clock. 

Programmable options include 1 , VA or 2 
stop bits; even, odd or no parity; and xl, 
xl6, x32 and x64 clock modes. 

Break generation and detection as well as 
parity-, overrun- and framing-error detec- 
tion are available. 



N 

00 

e 
a 



Description The Z-80 DART (Dual-Channel Asynchro- 

nous Receiver/Transmitter) is a dual-channel 
multi-function peripheral component that 
satisfies a wide variety of asynchronous serial 
data communications requirements in micro- 
computer systems. The Z-80 DART is used as a 
serial-to-parallel, parallel-to-serial converter/ 
controller in asynchronous applications. In 
addition, the device also provides modem con- 
trols for both channels. In applications where 



modem controls are not needed, these lines 
can be used for general-purpose I/O. 

Zilog also offers the Z-80 SIO, a more ver- 
satile device that provides synchronous 
(Bisync, HDLC and SDLC) as well as asyn- 
chronous operation. 

The Z-80 DART is fabricated with n-channel 
silicon-gate depletion-load technology, and is 
packaged in a 40-pin plastic or ceramic DIP. 
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Figure* 1. Z80 DART Pin Functions 



Figuro 2. Pin Assignments 



2044-002, 007 
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Pin. B/A. Channel A Or B Select (input, High 

Description selects Channel B). This input defines which 
channel is accessed during a data transfer be- 
tween the CPU and the Z-80 DART. 

C/D. Control Or Data Select (input, High 
selects Control). This input specifies the type 
of information (control or data) transferred on 
the data bus between the CPU and the Z-80 
DART. 

CE. Chip Enable (input, active Low). A Low at 
this input enables the Z-80 DART to accept 
command or data input from the CPU during a 
write cycle, or to transmit data to the CPU 
during a read cycle. 

CLK. System Clock (input). The Z-80 DART 
uses the standard Z-80 single-phase system 
clock to synchronize internal signals. 



as an interrupt acknowledge if the Z-80 DART 
is the highest priority device that has inter- 
rupted the Z-80 CPU. 



CTSA. CTSB. Clear To Send (inputs, active 
Low). When programmed as Auto Enables, a 
Low on these inputs enables the respective 
transmitter. If not programmed as Auto 
Enables, these inputs may be programmed as 
general-purpose inputs. Both inputs are 
Schmitt-trigger buffered to accommodate slow- 
risetime signals. 

D -D 7 . System Data Bus (bidirectional, 
3-state) transfers data and commands between 
the CPU and the Z-80 DART. 



DCDA, DCDB. Data Carrier Detect (inputs, 
active Low). These pins function as receiver 
enables if the Z-80 DART is programmed for 
Auto Enables; otherwise they may be used as 
general-purpose input pins. Both pins are 
Schmitt-trigger buffered. 



DTRA. DTRB. Data Terminal Beady (outputs, 
active Low). These outputs follow the state pro- 
grammed into the DTR bit. They can also be 
programmed as general-purpose outputs. 

IEI. Interrupt Enable In (input, active High) is 
used with IEO to form a priority daisy chain 
when there is more than one interrupt-driven 
device. A High on this line indicates that no 
other device of higher priority is being ser- 
viced by a CPU interrupt service routine. 

IEO. Interrupt Enable Out (output, active 
High). IEO is High only if IEI is High and the 
CPU is not servicing an interrupt from this 
Z-80 DART. Thus, this signal blocks lower 
priority devices from interrupting while a 
higher priority device is being serviced by its 
CPU interrupt service routine. 

INT. Interrupt Bequest (output, open drain, 
active Low). When the Z-80 DART is re- 
guesting an interrupt, it pulls INT Low. 

Ml. Machine Cycle One (input f rom Z-80 
CPU, active Low). When Ml and RD are both 
active, the Z-80 CPU is fetching an inst ructio n 
from memory; when Ml is active while IORQ is 
active, the Z-80 DART accepts Ml and IORQ 



IORQ. Input /Outp ut Bequest (input from CPU, 
active Low). IORQ is used in conjunction with 
B/A, C/D, CE and RD to transfer commands 
and data between the CPU and t he Z-80 
DART. When CE, RD and IORQ are all 
active, the channel selected by B/A transfers 
data to the CPU (a read operation). When CE 
and IORQ are active, but RD is inactive, the 
channel selected by B/A is written to by the 
CPU with eitherjdata or control information as 
specified by C/D. 

RxCA, RxCB. Beceiver Clocks (inputs). 
Rece ive data is sampled on the rising edge of 
RxC. The Receive Clocks may be 1, 16, 32 or 
64 times the data rate. 

RD. Bead C ycle Status, (input from CPU, ac- 
tive Low). If RD is active, a memory or I/O 
read operation is in progress. 

RxDA, RxDB. Beceive Data (inputs, active 
High). 



RESET. Beset (input, active Low). Disables 
both receivers and transmitters, forces TxDA 
and TxDB marking, forces the modem controls 
High and disables all interrupts. 

RIA . RIB. Bing Indicator (inputs , Ac tive 
Low) . These inputs are similar to CTS and 
DCD. The Z-80 DART detects both logic level 
transitions and interrupts the CPU. When not 
used in switched-line applications, these inputs 
can be used as general-purpose inputs. 

RTSA . RTSB. Bequest to Send (outputs, 

active Low). When the RTS bit is set, the RTS 
output goes Low. When the RTS bit is reset, 
the output goes High after the transmitter 
empties. 



TxCA. TxCB. Transmitter Clo cks (i nputs). TxD 
changes on the falling edge of TxC. The 
Transmitter Clocks may be 1, 16, 32 or 64 
times the data rate; however, the clock 
multiplier for the transmitter and the receiver 
must be the same. The Transmit Clock inputs 
are Schmitt-trigger buffered. Both the Receiver 
and Transmitter Clocks may be driven by the 
Z-80 CTC Counter Time Circuit for program- 
mable baud rate generation. 

TxDA, TxDB. Transmit Data (outputs, active 
High). 

W/RDYA. W/RDYB. Wait/Beady (outputs, 
open drain when programmed for Wait func- 
tion, driven High and Low when programmed 
for Ready function). These dual-purpose out- 
puts may be programmed as Ready lines for a 
DMA controller or as Wait lines that syn- 
chronize the CPU to the Z-80 DART data rate. 
The reset state is open drain. 
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Functional The functional capabilities of the Z-80 DART 

Description can be described from two different points of 
view: as a data communications device, it 
transmits and receives serial data, and meets 
the requirements of asynchronous data com- 
munications protocols; as a Z-80 family 
peripheral, it interacts with the Z-80 CPU and 
other Z-80 peripheral circuits, and shares the 
data, address and control buses, as well as 
being a part of the Z-80 interrupt structure. As 
a peripheral to other microprocessors, the Z-80 
DART offers valuable features such as non- 
vectored interrupts, polling and simple hand- 



shake capability. 

The first part of the following functional 
description introduces Z-80 DART data com- 
munications capabilities; the second part 
describes the interaction between the CPU and 
the Z-80 DART. 

A more detailed explanation of Z-80 DART 
operation can be found in the Z-80 SIO Tech- 
nical Manual (Document Number 03-3033-01). 
Because this manual was written for the 
Z-80 SIO, it contains information about syn- 
chronous as well as asynchronous operation. 



Communications Capabilities. The Z-80 
DART provides two independent full-duplex 
channels for use as an asynchronous 
receiver/transmitter. The following is a short 
description of receiver/transmitter capabilities. 
For more details, refer to the Asynchronous 
Mode section of the Z-80 SIO Technical 
Manual. The Z-80 DART offers transmission 
and reception of five to eight bits per 
character, plus optional even or odd parity. 
The transmitter can supply one, one and a half 
or two stop bits per character and can provide 
a break output at any time. The receiver break 
detection logic interrupts the CPU both at the 
start and end of a received break. Reception is 
protected from spikes by a transient spike re- 
jection mechanism that checks the signal one- 
half a bit time after a Low level is detected on 
the Receive Data input. If the Low does not 
persist — as in the case of a transient — the 
character assembly process is not started. 



Framing errors and overrun errors are 
detected and buffered together with the 
character on which they occurred. Vectored 
interrupts allow fast servicing of interrupting 
conditions using dedicated routines. Further- 
more, a built-in checking process avoids inter- 
prets r> ■> framing error as a new start bit: a 
franr ( or results in the addition of one-half 

a bit time to the point at which the search for 
the next start bit is begun. 

The Z-80 DART does not require symmetric 
Transmit and Receive Clock signals — a feature 
that allows it to be used with a Z-80 CTC or 
any other clock source. The transmitter and 
receiver can handle data at a rate of 1, 1/16, 
1/32 or 1/64 of the clock rate supplied to the 
Receive and Transmit Clock inputs. When 
using Channel B, the bit rates for transmit and 
rece ive o pera tions must be the same because 
RxC and TxC are bonded together (RxTxCB). 
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I/O Interface Capabilities. The Z-80 DART 
offers the choice of Polling, Interrupt (vectored 
or non-vectored) and Block Transfer modes to 
transfer data, status and control information to 



and from the CPU. The Block Transfer mode 
can be implemented under CPU or DMA 
control. 
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Functional POLLING. There are no interrupts in the 

Description Polled mode. Status registers RRO and.RRl are 
(Continued) updated at appropriate times for each function 
being performed. All the interrupt modes of 
the Z-80 DART must be disabled to operate the 
device in a polled environment. 

While in its Polling sequence, the CPU 
examines the status contained in RRO for each 
channel; the RRO status bits serve as an 
acknowledge to the Poll inquiry. The two RRO 



status bits D and D 2 indicate that a data 
transfer is needed. The status also indicates 
Error or other special status conditions (see 
"Z-80 DART Programming"). The Special 
Receive Condition status contained in RR1 
does not have to be read in a Polling sequence 
because the status bits in RR1 are accom- 
panied by a Receive Character Available 
status in RRO. 



INTERRUPTS. The Z-80 DART offers an 
elaborate interrupt scheme that provides fast 
interrupt response in real-time applications. As 
a member of the Z-80 family, the Z-80 DART 
can be daisy-chained along with other Z-80 
peripherals for peripheral interrupt-priority 
resolution. In addition, the internal interrupts 
of the Z-80 DART are nested to prioritize the 
various interrupts generated by Channels A 
and B. Channel B registers WR2 and RR2 con- 
tain the interrupt vector that points to an inter- 
rupt service routine in the memory. To 
eliminate the necessity of writing a status 
analysis routine, the Z-80 DART can modify the 
interrupt vector in RR2 so it points directly to 
one of eight interrupt service routines. This is 
done under program control by setting a pro- 
gram bit (WR1, D 2 ) in Channel B called 
"Status Affects Vector." When this bit is set, 
the interrupt vector in RR2 is modified accord- 
ing to the assigned priority of the various 
interrupting conditions. 

Transmit interrupts, Receive interrupts and 
External/Status interrupts are the main sources 
of interrupts. Each interrupt source is enabled 
under program control with Channel A having 
a higher priority than Channel B, and with 
Receiver, Transmit and External/Status inter- 
rupts prioritized in that order within each 
channel. When the Transmit interrupt is 
enabled, the CPU is interrupted by the 
transmit buffer becoming empty. (This implies 
that the transmitter must have had a data 
character written into it so it can become 



empty.) When enabled, the receiver can inter- 
rupt the CPU in one of three ways: 

■ Interrupt on the first received character 

■ Interrupt on all received characters 

■ Interrupt on a Special Receive condition 

Interrupt On First Character is typically 
used with the Block Transfer mode. Interrupt 
On All Receive Characters can optionally 
modify the interrupt vector in the event of 
a parity error. The Special Receive Condition 
interrupt can occur on a character basis. The 
Special Receive condition can cause an inter- 
rupt only if the Interrupt On First Receive 
Character or Interrupt On All Receive Char- 
acters mode is selected. In Interrupt On First 
Receive Character, an interrupt can occur 
from Special Receive conditions (except Parity 
Error) after the first receive character interrupt 
(example: Receive Overrun interrupt). 

The main function of the External/Status 
inte rrupt i s to m onitor the signal transitions of 
the CTS , DCD and RI pins; however, an 
External/Status interrupt is also caused by the 
detection of a Break sequence in the data 
stream. The interrupt caused by the Break 
sequence has a special feature that allows the 
Z-80 DART to interrupt when the Break 
sequence is detected or terminated. This 
feature facilitates the proper termination of the 
current message, correct initialization of the 
next message, and the accurate timing of the 
Break condition. 



CPU/DMA BLOCK TRANSFER. The Z-80 
DART provides a Block Transfer mode to 
accommodate CPU block transfer functions 
and DMA block transfers (Z-80 DMA or other 
designs ). The Block Transfer mode uses the 
W/RDY output in conjunction with the 
Wait/Re ady bits of Write Register 1 . The 
W/RDY output can be defined under software 
control as a Wait line in the CPU Block 



Transfer mode or as a Ready line in the DMA 
Block Transfer mode. 

To a DMA controller, the Z-80 DART Ready 
output indicates that the Z-80 DART is ready to 
transfer data to or from memory. To the CPU, 
the Wait output indicates that the Z-80 DART is 
not ready to transfer data, thereby requesting 
the CPU to extend the I/O cycle. 
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Internal The device internal structure includes a Z-80 

Architecture CPU interface, internal control and interrupt 
logic, and two full-duplex channels. Each 
channel contains read and write registers, and 
discrete control and status logic that provides 
the interface to modems or other external 
devices. 

The read and write register group includes 
five 8-bit control registers and two status 
registers. The interrupt vector is written into 
an additional 8-bit register (Write Register 2) 
in Channel B that may be read through Read 
Register 2 in Channel B. The registers for both 
channels are designated as follows: 

WR0-WR5 — Write Registers through 5 
RR0-RR2 — Read Registers through 2 

The bit assignment and functional grouping 
of each register is configured to simplify and 



organize the programming process. 

The logic for both channels provides for- 
mats, bit synchronization and validation for 
data transferred to and from the channel inter- 
face^ The modem control inp uts C lear to Send 
(CTS), DataCarrier Detect (DCD) and Ring 
Indicator (RI ) are monitored by the control 
logic under program control. All the modem 
control signals are general purpose in nature 
and can be used for functions other than 
modem control. 

For automatic interrupt vectoring, the inter- 
rupt control logic determines which channel 
and which device within the channel has the 
highest priority. Priority is fixed with Channel 
A assigned a higher priority than Channel B; 
Receive, Transmit and External/Status inter- 
rupts are prioritized in that order within each 
channel. 



Data Path. The transmit and receive data path 
illustrated for Channel A in Figure 4 is iden- 
tical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement in 
addition to the 8-bit receive shift register. This 
scheme creates additional time for the CPU to 



service a Receive Character Available inter- 
rupt in a high-speed data transfer. 

The transmitter has an 8-bit transmit data 
register that is loaded from the internal data 
bus, and a 9-bit transmit shift register that is 
loaded from the transmit data register. 
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Read. 
Write and 
Interrupt 
Timing 



Read Cycle. The timing signals generated by 
a Z-80 CPU input instruction to read a Data or 



Status byte from the Z-80 DART are illustrated 
in Figure 5a. 



Write Cycle. Figure 5b illustrates the timing 
and data signals generated by a Z-80 CPU out- 



put instruction to write a Data or Control byte 
into the Z-80 DART. 



Interrupt Acknowledge Cycle. Afte r receiv- 
ing an Interrupt Reguest signal (INT pulled 
Low), the Z-80 CPU sends an Interru pt 
Acknowledge signal (Ml and IORQ both Low). 
The daisy-chained interrupt circuits determine 
the highest priority interrupt reguestor. The IEI 
of the highest priority peripheral is terminated 
High. For any peripheral that has no interrupt 
pending or under service, IEO = IEI. Any 
peripheral that does have an interrupt pending 
or under service forces its IEO Low. 



To insure stable conditions in the daisy 
chain, all interrupt status signals are pr evente d 
from changing while Ml is Low. When IORQ is 
Low, the highest priority interrupt reguestor 
(the one with IEI High) places its interrupt vec- 
tor on the data bus and sets its internal 
interrupt-under-service latch. 

Refer to the Z-80 SIO Technical Manual for 
additional details on the interrupt daisy chain 
and interrupt nesting. 



Return From Interrupt Cycle. Normally, the 
Z-80 CPU issues an RETI (Return From Inter- 
rupt) instruction at the end of an interrupt ser- 
vice routine. RETI is a 2-byte opcode (ED-4D) 
that resets the interrupt-under-service latch to 
terminate the interrupt that has just been 
processed. 



When used with other CPUs, the Z-80 DART 
allows the user to return from the interrupt 
cycle with a special command called "Return 
From Interrupt" in Write Register of Channel 
A. This command is interpreted by the Z-80 
DART in exactly the same way it would inter- 
pret an RETI command on the data bus. 
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Figure 5a. Read Cycle 



Figure 5b. Write Cycle 
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Figure 5c. Interrupt Acknowledge Cycle 



Figure 5d. Return from Interrupt Cycle 
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Z-80 DART To program the Z-80 DART, the system pro- 

Programming gram first issues a series of commands that 

initialize the basic mode and then other com- 
mands that qualify conditions within the select- 
ed mode. For example, the character length, 
clock rate, number of stop bits, even or odd 
parity are first set, then the Interrupt mode 
and, finally, receiver or transmitter enable. 



Both channels contain command registers 
that must be programmed via the system pro- 
gram prior to operation. The Channel Select 
input (B/A) and the Control/Data input (C/D) 
are the command structure addressing con- 
trols, and are normally controlled by the CPU 
address bus. 



Write Registers. The Z-80 DART contains six 
registers (WR0-WR5) in each channel that are 
programmed separately by the system program 
to configure the functional personality of the 
channels (Figure 4). With the exception of 
WRO, programming the write registers requires 
two bytes. The first byte contains three bits 
(D -D 2 ) that point to the selected register; the 
second byte is the actual control word that is 
written into the register to configure the Z-80 
DART. 

WRO is a special case in that all the basic 
commands (CMD -CMD 2 ) can be accessed 
with a single byte. Reset (internal or external) 
initializes the pointer bits D -D 2 to point to 
WRO. This means that a register cannot be 



pointed to in the same operation as a channel 
reset. 



Write Register Functions 

WRO Register pointers, initialization commands for 
the various modes, etc. 

WR1 Transmit/Receive interrupt and data transfer 
mode definition. 

WR2 Interrupt vector (Channel B only) 

WR3 Receive parameters and control 

WR4 Transmit/Receive miscellaneous parameters 
and modes 

WR5 Transmit parameters and controls 
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Read Registers. The Z-80 DART contains 
three registers (RR0-RR2) that can be read to 
obtain the status information for each channel 
(except for RR2, which applies to Channel B 
only). The status information includes error 
conditions, interrupt vector and standard 
communications-interface signals. 

To read the contents of a selected read 
register other than RRO, the system program 
must first write the pointer byte to WRO in 
exactly the same way as a write register opera- 
tion. Then, by executing an input instruction, 
the contents of the addressed read register can 
be read by the CPU. 



The status bits of RRO and RR1 are carefully 
grouped to simplify status monitoring. For 
example, when the interrupt vector indicates 
that a Special Receive Condition interrupt has 
occurred, all the appropriate error bits can be 
read from a single register (RR1). 

Read Register Functions 

RRO Transmit/Receive buffer status, interrupt 
status and external status 

RR1 Special Receive Condition status 

RR2 Modified interrupt vector (Channel B only) 
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Z-80 DART 
Read and Write 
Registers 



READ REGISTER 

| D, D 8 | D. D, D 3 | D 2 | D, | D | 



L!: 



L Rx CHARACTER AVAILABLE 
INT PENDING (CH. A ONLY) 



Tx BUFFER EMPTY 

DCO 

Rl 



CTS 
NOT USED 
BREAK 



USED WITH "EXTERNAL/ 
> STATUS INTERRUPT" 
MODE 



READ REGISTER 1* 

I D, I 0, | D s I D 4 I D 3 I Oj 



LEUD 



L ALL SENT 
NOT USED 



. PARITY ERROR 

■ Rx OVERRUN ERROR 

■ FRAMING ERROR 

■ NOT USED 



"Used With Special Receive Condition Mode 



READ REGISTER 2 

| D ; | D, | D s | D, | D 3 | D 2 | D, | D | 



L±: 



"Variable II "'Status Affect 
Vector" Is Programmed 



WRITE REGISTER 

|"d7 D, I D 5 | 0, | D a | D; | D, | Dp | 



REGISTER 
REGISTER 1 
REGISTER 2 
REGISTER 3 
REGISTER 4 
REGISTER 5 



NULL CODE 
NOT USED 

RESET EXT/STATUS INTERRUPTS 
CHANNEL RESET 

ENABLE INT ON NEXT Rx CHARACTER 
RESET TxINT PENDING 
ERROR RESET 

RETURN FROM INT (CHA ONLY) 
-NOT USED 



WRITE REGISTER 1 

| D, I D 8 | Pi | D, | D a | D 2 | D, | D„ | 





1 

1 



L^ 



EXT INT ENABLE 
TxINT ENABLE 
STATUS AFFECTS VECTOR 
(CH. B ONLY) 



Rx INT DISABLE 

Rx INT ON FIRST CHARACTER 

INT ON ALL Rx CHARACTERS (PARITY 

AFFECTS VECTOR) 
INT ON ALL Rx CHARACTERS (PARITY 

DOES NOT AFFECT VECTOR) 
WAIT/READY ON R/T 
WAIT/READY FUNCTION 
WAIT/READY ENABLE 



OR ON 
SPECIAL 
RECEIVE 
CONDITION 



WRITE REGISTER 2 (CHANNEL B ONLY) 



| D, | D 6 



D s D, D, D; 



EH 



[±: 



WRITE REGISTER 3 



| 0, | 8 | D 5 | D 4 | D 3 | D; | D, | D„ | 

— r~ — i — l 



AUTO ENABLES 



Rx S BITS/CHARACTER 
Rx 7 8ITS/CHARACTER 
Rx 6 BITS/CHARACTER 
Rx 8 BITS/CHARACTER 



WRITE REGISTER 4 



Lh 



L- PARITY ENABLE 
PARITY EVEN/5BB 



NOT USED 

1 STOP BIT/CHARACTER 
1Vi STOP BITS/CHARACTER 

2 STOP BITS/CHARACTER 



X1 CLOCK MODE 
X16 CLOCK MODE 
X32 CLOCK MODE 
X64 CLOCK MODE 



WRITE REGISTER 5 



i | D, | D, I D; I 0, | Dp 



L^ 



NOT USED 

RTS 

NOT USED 

Tx ENABLE 

SEND BREAK 



Tx 5 BITS (OR LESSVCHARACTER 
Tx 7 BITS/CHARACTER 
Tx 6 BITS/CHARACTER 
Tx 8 BITS/CHARACTER 
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Appendex B - Z80A PIO 



23420 

Z80® PIO Parallel 

Input/Output Controller 




Zilog 



Product 
Specification 



March 1981 



Features ■ Provides a direct interface between Z-80 

microcomputer systems and peripheral 
devices. 

■ Both ports have interrupt-driven handshake 
for fast response. 

■ Four programmable operating modes: byte 
input, byte output, byte input/output (Port A 
only), and bit input/output. 



Programmable interrupts on peripheral 
status conditions. 

Standard Z-80 Family bus-request and 
prioritized interrupt-request daisy chains 
impl' "tented without external logic. 

The eight Port B outputs can drive Dar- 
lington transistors (1.5 mA at 1.5 V). 
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General The Z-80 PIO Parallel I/O Circuit is a pro- 

Description grammable, dual-port device that provides a 
TTL-compatible interface between peripheral 
devices and the Z-80 CPU. The CPU config- 
ures the Z-80 PIO to interface with a wide 
range of peripheral devices with no other 
external logic. Typical peripheral devices that 
are compatible with the Z-80 PIO include most 
keyboards, paper tape readers and punches, 
printers, PROM programmers, etc. 

One characteristic of the Z-80 peripheral 
controllers that separates them from other 
interface controllers is that all data transfer 
between the peripheral device and the CPU is 
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accomplished under interrupt control. Thus, 
the interrupt logic of the PIO permits full use 
of the efficient interrupt capabilities of the 
Z-80 CPU during I/O transfers. All logic 
necessary to implement a fully nested interrupt 
structure is included in the PIO. 

Another feature of the PIO is the ability to 
interrupt the CPU upon occurrence of speci- 
fied status conditions in the peripheral device. 
For example, the PIO can be programmed to 
interrupt if any specified peripheral alarm con- 
ditions should occur. This interrupt capability 
reduces the time the processor must spend in 
polling peripheral status. 
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Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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General The Z-80 PIO interfaces to peripherals via 

Description two independent general-purpose I/O ports, 
(Continued) designated Port A and Port B. Each port has 
eight data bits and two handshake signals, 
Ready and Strobe, which control data transfer. 
The Ready output indicates to the peripheral 
that the port is ready for a data transfer. 
Strobe. is an input from the peripheral that 
indicates when a data transfer has occurred. 

Operating Modes. The Z-80 PIO ports can be 
programmed to operate in four modes: byte 
output (Mode 0), byte input (Mode 1), byte 
input/output (Mode 2) and bit input/output 
(Mode 3). 

In Mode 0, either Port A or Port B can be 
programmed to output data. Both ports have 
output registers that are individually addressed 
by the CPU; data can be written to either port 
at any time. When data is written to a port, an 
active Ready output indicates to the external 
device that data is available at the associated 
port and is ready for transfer to the external 
device. After the data transfer, the external 
device responds with an active Strobe input, 
which generates an interrupt, if enabled. 

In Mode 1 , either Port A or Port B can be 
configured in the input mode. Each port has 
an input register addressed by the CPU. When 
the CPU reads data from a port, the PIO sets 
the Ready signal, which is detected by the 
external device. The external device then 
places data on the I/O lines and strobes the 
I/O port, which latches the data into the Port 
Input Register, resets Ready, and triggers the 
Interrupt Request, if enabled. The CPU can 
read the input data at any time, which again 
sets Ready. 

Mode 2 is bidirectional and uses Port A, 
plus the interrupts and handshake signals from 
both ports. Port B must be set to Mode 3 and 
masked off. In operation, Port A is used for 
both data input and output. Output operation 
is similar to Mode except that da ta is a llowed 
out onto the Port A bus only when ASTB is 
Low. For input, operation is similar to Mode 1, 
except that the data input uses the Port B 
handshake signals and the Port B interrupt (if 
enabled). 

Both ports can be used in Mode 3. In this 
mode, the individual bits are defined as either 
input or output bits. This provides up to eight 
separate, individually defined bits for each 
port. During operation, Ready and Strobe are 



not used. Instead, an interrupt is generated if 
the condition of one input changes, or if all 
inputs change. The requirements for gener- 
ating an interrupt are defined during the pro- 
gramming operation; the active level is 
specified as either High or Low, and the logic 
condition is specified as either one input active 
(OR) or all inputs active (AND). For example, 
if the port is programmed for active Low 
inputs and the logic function is AND, then all 
inputs at the specified port must go Low to 
generate an interrupt. 

Data outputs are controlled by the CPU and 
can be written or changed at any time. 

■ Individual bits can be masked off. 

■ The handshake signals are not used in 
Mode 3; Ready is held Low, and Strobe is 
disabled. 

■ When using the Z-80 PIO interrupts, the 
Z-80 CPU interrupt mode must be set to 
Mode 2. 




Figure 3. PIO in a Typical Z80 Family Environment 
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Internal The internal structure of the Z-80 PIO con- 

Structure sists of a Z-80 CPU bus interface, internal con- 

trol logic, Port A I/O logic, Port B I/O logic, 
and interrupt control logic (Figure 4). The 
CPU bus interface logic allows the Z-80 PIO to 
interface directly to the Z-80 CPU with no 
other external logic. The internal control logic 
synchronizes the CPU data bus to the per- 
ipheral device interfaces (Port A and Port B). 
The two I/O ports (A and B) are virtually 
identical and are used to interface directly to 
peripheral devices. 

Port Logic. Each port contains separate input 
and output registers, handshake control logic, 
and the control registers shown in Figure 5. 
All data transfers between the peripheral unit 
and the CPU use the data input and output 
registers. The handshake logic associated with 
each port controls the data transfers through 
the input and the output registers. The mode 
control register (two bits) selects one of the 
four programmable operating modes. 

The control mode (Mode 3) uses the remain- 
ing registers. The input/output control register 
specifies which of the eight data bits in the 
port are to be outputs and enables these bits; 
the remaining bits are inputs. The mask reg- 
ister and the mask control register control 
Mode 3 interrupt conditions. The mask register 
specifies which of the bits in the port are 
' active and which are masked or inactive. 



The mask control register specifies two 
conditions: first, whether the active state of 
the input bits is High or Low, and second, 
whether an interrupt is generated when any 
one unmasked input bit is active (OR condi- 
tion) or if the interrupt is generated when 
all unmasked input bits are active (AND 
condition). 

Interrupt Control Logic. The interrupt control 
logic section handles all CPU interrupt pro- 
tocol for nested- priority interrupt structures. 
Any device's physical location in a daisy-chain 
configuration determines its priority. Two lines 
(IEI and IEO) are provided in each PIO to 
form this daisy chain. The device closest to the 
CPU has the highest priority. Within a PIO, 
Port A interrupts have higher priority than 
those of Port B. In the byte input, byte output, 
or bidirectional modes, an interrupt can be 
generated whenever the peripheral reguests a 
new byte transfer. In the bit control mode, an 
interrupt can be generated when the periph- 
eral status matches a programmed value. The 
PIO provides for complete control of nested 
interrupts. That is, lower priority devices may 
not interrupt higher priority devices that have 
not had their interrupt service routines com- 
pleted by the CPU. Higher priority devices 
may interrupt the servicing of lower priority 
devices. 
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Figure 4. Block Diagram 
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Internal If the CPU (in interrupt Mode 2) accepts an 

Structure interrupt, the interrupting device must provide 

(Continued) an 8-bit interrupt vector for the CPU. This vec- 
tor forms a pointer to a location in memory 
where the address of the interrupt service 
routine is located. The 8-bit vector from the 
interrupting device forms the least significant 
eight bits of the indirect pointer while the 
I Register in the CPU provides the most signifi- 
cant eight bits of the pointer. Each port (A and 
B) has an independent interrupt vector. The 
least significant bit of the vector is automati- 
cally set to within the PIO because the 
pointer must point to two adjacent memory 
locations for a complete 16- bit address. 

Unlike the other Z-80 peripherals, the PIO 
does not enable interrupts immediately after 
programming. It waits until Ml goes Low (e.g., 
during an opcode fetch). This condition is 
unimportant in the Z-80 environment but might 
not be if another type of CPU is used. 
The PIO decodes the RETI (Return From 



Interrupt) instruction directly from the CPU 
data bus so that each PIO in the system knows 
at all times whether it is being serviced by the 
CPU interrupt service routine. No other com- 
munication with the CPU is required. 

CPU Bus I/O Logic. The CPU bus interface 
logic interfaces the Z-80 PIO directly to the 
Z-80 CPU, so no external logic is necessary. 
For large systems, however, address decoders 
and/or buffers may be necessary. 

Internal Control Logic. This logic receives the 
control words for each port during program- 
ming and, in turn, controls the operating func- 
tions of the Z-80 PIO. The control logic syn- 
chronizes the port operations, controls the port 
mode, port addressing, selects the read/write 
function, and issues appropriate commands to 
the ports and the interrupt logic. The Z-80 PIO 
does not re ceive a w rite input from t he CPU; 
instead, the RD, CE, C/D and IORQ signals 
generate the write input internally. 
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Figure 5. Typical Port I/O Block Diagram 
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Programming Mode 0. 1. or 2. (Byte Input, Output, or 

Bidirectional). Programming a port for Mode 
0, 1, or 2 requires two words per port. These 
words are: 

A Mode Control Word. Selects the port operating mode 
(Figure 6). This word may be written any time. 

An Interrupt Vector. The Z-80 PIO is designed for use with 
the Z-80 CPU in interrupt Mode 2 (Figure 7). When inter- 
rupts are enabled, the PIO must provide an interrupt 
vector. 

Mode 3. (Bit Input/Output). Programming a 
port for Mode 3 operation requires a control 
word, a vector (if interrupts are enabled), and 
three additional words, described as follows: 

I/O Register Control. When Mode 3 is selected, the mode 
control word must be followed by another control word that 
sets the I/O control register, which in turn defines which 
port lines are inputs and which are outputs (Figure 8). 
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DON'T CARE 
MODE SELECT 

MODE0 
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Interrupt Control Word. In Mode 3, handshake is not 
used. Interrupts are generated as a logic function of the 
input signal levels. The interrupt control word sets the 
logic conditions and the logic levels required for gener- 
ating an interrupt. Two logic conditions or functions are 
available: AND (if all input bits change to the active level, 
an interrupt is triggered), and OR (if any one of the input 
bits changes to the active level, an interrupt is triggered). 
Bit D5 sets the logic function, as shown in Figure 9. The 
active level of the input bits can be set either High or Low. 
The active level is controlled by Bit D5. 

Mask Control Word. This word sets the mask control 
register, allowing any unused bits to be masked off. If any 
bits are to be masked, then D4 must be set. When D4 is set, 
the next word written to the port must be a mask control 
word (Figure 10). 

Interrupt Disable. There is one other control 
word which can be used to enable or disable a 
port interrupt. It can be used without changing 
the rest of the interrupt control word 
(Figure 11). 
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D< < NO MASK WORK FOLLOWS 
D 4 - 1 MASK WORD FOLLOWS 

D5 - ACTIVE LEVEL IS LOW 
D s » 1 ACTIVE LEVEL IS HIGH 

D« - INTERRUPT ON OR FUNCTION 
D« - 1 INTERRUPT ON AND FUNCTION 

Dj =■ INTERRUPT DISABLED 
D 7 - 1 INTERRUPT ENABLED* 



■NOTE: THE PORT IS NOT ENABLED UNTIL 

THE INTERRUPTJNABLE IS FOLLOWED 
BY AN ACTIVE Ml. 



Figure 6. Mode Control Word 



Figure 9. Interrupt Control Word 
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Figure 7. Interrupt Vector Word 



Figure 10. Mask Control Word 
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Figure 8. I/O Register Control Word 



Figure 11. Interrupt Disable Word 
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Pin A0-A7. Port A Bus (bidirectional, 3-state). 

Description This 8-bit bus transfers data, status, or control 
information between Port A of the PIO and a 
peripheral device, Ao is the least significant 
bit of the Port A data bus. 

ARDY. Eegister A Ready (output, active 
High). The meaning of this signal depends on 
the mode of operation selected for Port A as 
follows: 

Output Mode. This signal goes active to indicate that the 
Port A output register has been loaded and the peripheral 
data bus is stable and ready for transfer to the peripheral 
device. 

Input Mode. This signal is active when the Port A input 
register is empty and ready to accept data from the 
peripheral device. 

Bidirectional Mode. This signal is active when data is 
available in the Port A output register for transfer to the 
peripheral device. In th is mod e, data is not placed on the 
Port A data bus, unless ASTB is active. 

Control Mode. This signal is disabled and forced to a Low 
state. 



ASTB. Port A Strobe Pulse From Peripheral 
Device (input, active Low). The meaning of 
this signal depends on the mode of operation 
selected for Port A as follows: 

Output Mode. The positive edge of this strobe is issued by 
the peripheral to acknowledge the receipt of data made 
available by the PIO. 

Input Mode. The strobe is issued by the peripheral to load 
data from the peripheral into the Port A input register. 
Data is loaded into the PIO when this signal is active. 

Bidirectional Mode. When this signal is active, data from 
the Port A output register is gated onto the Port A bidirec- 
tional data bus. The positive edge of the strobe acknowl- 
edges the receipt of the data. 

Control Mode. The strobe is inhibited internally. 

B0-B7. Port B Bus (bidirectional, 3-state). This 
8-bit bus transfers data, status, or control 
information between Port B and a peripheral 
device. The Port B data bus can supply 
1.5 mA at 1.5 V to drive Darlington transistors. 
Bo is the least significant bit of the bus. 

B/A. Port B Or A Select (input, High = B). 
This pin defines which port is accessed during 
a data transfer between the CPU and the PIO. 
A Low on this pin selects Port A; a High 
selects Port B. Often address bit Ao from the 
CPU is used for this selection function. 

BRDY. Register B Beady (output, active High). 
This signal is similar to ARDY, except that in 
the Port A bidirectional mode this signal is 
High when the Port A input register is empty 
and ready to accept data from the peripheral 
device. 



C/D. Control Or Data Select (input, 
High = C). This pin defines the type of data 
transfer to be performed between the CPU and 
the PIO. A High on this pin during a CPU 
write to the PIO causes the Z-80 data bus to be 
interpreted as a command for the port selected 
by the B/A Select line. A Low on this pin 
means that the Z-80 data bus is being used to 
transfer data between the CPU and the PIO. 
Often address bit A\ from the CPU is used for 
this function. 

CE. Chip Enable (input, active Low). A Low 
on this pin enables the PIO to accept com- 
mand or data inputs from the CPU during a 
write cycle or to transmit data to the CPU dur- 
ing a read cycle. This signal is generally 
decoded from four I/O port numbers for Ports 
A and B, data, and control. 
CLK. System Clock (input). The Z-80 PIO uses 
the standard single-phase Z-80 system clock. 

D0-D7. Z-80 CPU Data Bus (bidirectional, 
3-state). This bus is used to transfer all data 
and commands between the Z-80 CPU and the 
Z-80 PIO. Do is the least significant bit. 

IEI. Interrupt Enable In (input, active High). 
This signal is used to form a priority-interrupt 
daisy chain when more than one interrupt- 
driven device is being used. A High level on 
this pin indicates that no other devices of 
higher priority are being serviced by a CPU 
interrupt service routine. 

IEO. Interrupt Enable Out (output, active 
High). The IEO signal is the other signal 
reguired to form a daisy chain priority scheme. 
It is High only if IEI is High and the CPU is 
not servicing an interrupt from this PIO. Thus 
this signal blocks lower priority devices from 
interrupting while a higher priority device is 
being serviced by its CPU interrupt service 
routine. 

INT. Interrupt Beq uest (output, open drain, 
active Low). When INT is active the Z-80 PIO 
is reguesting an interrupt from the Z-80 CPU. 



BSTB. Port B Strobe Pulse From Peripheral 
Device (i nput, a ctive Low). This signal is 
similar to ASTB, except that in the Port A 
bidirectional mode this signal strobes data 
from the peripheral device into the Port A 
input register. 



IORQ. Input/Outp ut Beq uest (input from Z-80 
CPU, active Low). I ORQ is used in conjunc- 
tion with B/A, C/D, CE, and RD to transfer 
commands and data betw een the Z-80 C PU and 
the Z-80 PIO. When CE, RD, and IORQ are 
active, the port addressed by B/A transfers 

data to the CP U (a rea d oper ation). Con- 

versely, when CE and IORQ are_active but RD 
is not, the port addressed by B/A is written 
into from the CPU with either data or control 
inform ation, as specified by C/D. Also, if 
IORQ and Ml are active simultaneously, the 
CPU is acknowledging an interrupt; the inter- 
rupting port automatically places its interrupt 
vector on the CPU data bus if it is the highest 
priority device reguesting an interrupt. 
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Pin Ml. Machine Cycle (input from CPU, active 

Description Low). This signal is used as a sync pulse to 
(Continued) control several internal PIO operations. When 
1 both the Ml and RD signals are active, the 
j Z-80 CPU is fetching an instruction trom 
J memo ry. Conversely, when both Ml and 
; IORQ are active, the CPU is acknowledging 
an interrupt. In addition, Ml has two other 
functions within the Z-80 PIO: it synchronizes 



the PIO interrupt Jogic; when Ml occurs 
without an active RD or IORQ signal, the PIO 
is reset. 

RD. Bead Cycle Status (input from Z-80 CPU, 
active Low). If RD is active, or an I/O opera- 
tion is in progr ess, RD is used with B/A, C/D, 
CE, and IORQ to transfer data from the Z-80 
PIO to the Z-80 CPU. 



Timing The following timing diagrams show typical 

timing in a Z-80 CPU environment. For more 
precise specifications refer to the composite 
ac timing diagram. 

Write Cycle. Figure 12 illustrates the 
timing for programming the Z-80 PIO 
or for writing data to one of its ports. No 
Wait states are allowed for writing to the 
PIO other than the automatically inserted 
Ty/A- The PIO does not receive a speci- 
fic write signal; it internally generates 
its own from the lack of an active 
RD signal. 
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Read Cycle. Figure 13 illustrates the timing 
for reading the data input from an external 
device to one of the Z-80 PIO ports. No Wait 
states are allowed for reading the PIO other 
than the automatically inserted Ty/A- 

Output Mode (Mode 0). An output cycle 
(Figure 14) is always started by the execu tion 
of an output instruction by the CPU. The WR* 
pulse from the CPU latches the data from the 
CPU data bu s int o the selected port's output 
register. The WR* pulse sets the Ready flag 
after a Low-going edge of CLK, indicating 
data is available. Ready stays active until the 
positive edge of the . trobe line is received, 
indicating that data was taken by the periph- 
eral. The pos itive edge of the strobe pulse 
generates an INT if the interrupt enable flip- 
flop has been set and if this device has the 
highest priority. 
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•RD = RD • CE • C/D • IORQ 
Figure 13. Read Cycle Timing 




*WR = RD • CE • CTD • IORQ 

Figure 14. Mode Output Timing 
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Timing Input Mode (Mode 1). When STROBE goes 

(Continued) Low, data is loaded into the selected port input 
register (Figure 15) . The next rising edge of 
strobe activates INT, if Interrupt Enable is set 
and this is the highest-priority reguesting 
device. The following falling edge of CLK 
resets Ready to an inactive state, indicating 



that the input register is full and cannot accept 
any more data until the CPU completes a read. 
When a read is complete, the positive edge of 
RD sets Ready at the next Low-going transition 
of CLK. At this time new data can be loaded 
into the PIO. 




*RD = RD • CE • C/D • IORQ 

Figure 15. Mode 1 Input Timing 



Bidirectional Mode (Mode 2). This is a com- 
bination of Modes and 1 using all four hand- 
shake lines and the eight Port A I/O lines 
(Figure 16). Port B must be set to the bit mode 
and its inputs must be masked. The Port A 
handshake lines are used for output control 
and the Port B lines are used for input control. 



If interrupts occur, Port A's vector will be used 
during port output and Port B's will be used 
during port input. Dat a is al lowed out onto the 
Port A bus only when ASTB is Low. The rising 
edge of this strobe can be used to latch the 
data into the peripheral. 




*WR = RD • CE • C/D • IORQ 

Figure 16. Mode 2 Bidirectional Timing 
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Timing Bit Mode (Mode 3). The bit mode does not 

(Continued) utilize the handshake signals, and a normal 

port write or port read can be executed at any 
time. When writing, the data is latched into 
the output registers with the same timing as the 
output mode (Figure 17). 

When reading the PIO, the data returned to 
the CPU is composed of output register data 
from those port data lines assigned as outputs 
and input register data from those port data 



lines assigned as inputs. The input register 
contains data that was pres ent immediately 
prior to the falling edge of RD. An interrupt is 
generated if interrupts from the port are 
enabled and the data on the port data lines 
satisfy the logical equation defined by the 8-bit 
mask and 2-bit mask control registers. How- 
ever, if Port A is programmed in bidirectional 
mode, Port B does not issue an interrupt in bit 
mode and must therefore be polled. 
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Figuro 17. Mode 3 Bit Mode Timing 



Interrupt Acknowledge Timing. During Ml 
time, peripheral controllers are inhibited from 
changing their interrupt enable status, permit- 
ting the Interrupt Enable signal to ripple 
through the daisy chain. The periphera l with 
IEI High and IEO Low during INTACK places 
a preprogrammed 8-bit interrupt vector on the 
data bus at this time (Figure 18). IEO is held 
Low until a Return From Interrupt (RETI) 
instruction is executed by the CPU while IEI is 
High. The 2-byte RETI instruction is decoded 
internally by the PIO for this purpose. 
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INDICATE 
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Figure 18. Interrupt Acknowledge Timing 



Return From Interrupt Cycle. If a Z-80 per- 
ipheral has no interrupt pending and is not 
under service, then its IEO = IEI. If it has an 
interrupt under service (i.e., it has already 
interrupted and received an interrupt acknowl- 
edge) then its IEO. is always Low, inhibiting 
lower priority devices from interrupting. If it 
has an interrupt pending which has not yet 
been acknowledged, IEO is Low unless an 
,V ED" is decoded as the first byte of a 2-byte 
opcode (Figure 19). In this case, IEO goes 
High until the next opcode byte is decoded, 
whereupon it goes Low again. If the second 
byte of the opcode was a "4D," then the 
opcode was an RETI instruction. 

After an "ED" opcode is decoded, only the 
peripheral device which has interrupted and is 
currently under service has its IEI High and its 



IEO Low. This device is the highest-priority 
device in the daisy chain that has received an 
interrupt acknowledge. All other peripherals 
have IEI = IEO. If the next opcode byte 
decoded is "4D," this peripheral device resets 
its "interrupt under service" condition. 
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Figure 19. Return From Interrupt 
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Number Symbol 


Parameter 


Z-80PIO 
Mln Max 
(ns) (ns) 


Z-80A PIO 
Mln Max 
(ns) (ns) 


Z-80B PI0191 
Mln Max 
(ns) (ns) 


Comment 


1 


TcC 


Clock Cycle Time 


400 


[1] 


250 


[1] 


165 


[1] 




2 


TwCh 


Clock Width (High) 


170 


2000 


105 


2000 


65 


2000 




3 


TwCl 


Clock Width (Low) 


170 


2000 


105 


2000 


65 


2000 




4 


TfC 


Clock Fall Time 




30 




30 




20 




5 


TrC 


Clock Rise Time 




30 " 




30 




20 




6 


TsCS(RI) 


CE, B/A, C/D to RD, 
IORQ I Setup Time 


50 




50 




50 




[6] 


7 


Th 


Any Hold Times for Specified 
Setup Time 




















8 


TsRI(C) 


RD, IORQ to Clock t Setup 
Time 


115 




115 




70 






9- 




















300 


[2] 


10 


TdRI(DOs) 


RD, IORQ t to Data Out Float 
Delay 




160 




110 




70 




11 


TsDI(C) 


Data In to Clock t Setup Time 


50 




50 




40 




CL = 50 pF 


12 


TdlO(DOI) 


IORQ I to Data Out Delay 
(INTACK Cycle) 


340 




160 




120 




[3] 


13- 


-TsMl(Cr) 


Ml 1 to Clock t Setup Time 


- 210— 
























14 


TsMl(Cf) 


Ml t to Clock I Setup Time 
(Ml Cycle) 

















[8] 


15 


TdMl(IEO) 
TsIEI(IO) 
-TdlEI(IEOf)— 


Ml 1 to IEO 1 Delay (Interrupt 
Immediately Preceding Ml I) 


140 


300 


140 


190 


100 


100 


[5,7] 


16 
17- 


IEI to IORQ 1 Setup Time 
(INTACK Cycle) 


[7] 
















CL = 50 pF 


18 


TdlEI(IEOr) 


IEI t to IEO t Delay (after ED 
Decode) 




210 




160 




160 


[5] 


19 


TcIO(C) 


IORQ t to Clock 1 Setup Time 
(To Activate READY on Next 
Clock Cycle) 


220 




200 




170 






20- 


-TdC(RDYr) — 




-200- 




-190— 




-170— 




[5] 

CL = 50 pF 




21 


TdC(RDYf) 


Clock 1 to READY t Delay 


150 




140 




120 




[5] 


22 


TwSTB 
TsSTB(C) 


STROBE Pulse Width 


150 
220 




150 
220 




120 
150 




[4] 


23 


STROBE t to Clock 1 Setup 
Time (To Activate READY on 
Next Clock Cycle) 


[5] 


24 


-TdlO(PD) 

TsPD(STB) 


- IORQ 1 to PORT DATA Stable 
Delay (Mode 0) 


















260 


200 


230 


180 


190 


160 


[5] 


25 


PORT DATA to STROBE t 
Setup Time (Mode 1) 




26 


TdSTB(PD) 


STROBE 1 to PORT DATA 
Stable (Mode 2) 




230 




210 




180 


[5] 


27 - 


-TdSTB(PDr)— 


-STROBE 1 to PORT DATA Float - 
Delay (Mode 2) 


















200 




180 




160 


CL = 50 pF 


28 


TdPD(INT) 


PORT DATA Match to INT J 
Delay (Mode 3) 




540 




490 




430 




29 


TdSTB(INT) 


STROBE I to INT I Delay 




490 




440 




350 





N 

00 

o 



NOTES: 
[1] TcC = TwCh + TwCl + TrC + TfC. 
[2] Increase TdRI(DO) by 10 ns lor each 50 pF increase in load 

up to 200 pF max. 
[3] Increase TdlO(DOI) by 10 ns for each 50 pF, increase in 

loading up to 200 pF max. 
[4] For Mode 2: TwSTB > TsPD(STB). 
[5] Increase these values by 2 ns for each 10 pF increase in 

loading up to 100 pF max. 



|6] TsCS(RI) may be reduced. However, the time subtracted 

from TsCS(RI) will be added to TdRI(DO). 
[7] 2.5 TcC > (N-2)TdIEI(IEOf) + TdMl(IEO) + TsIEI(IO) 

_+ TTL Buffer Delay, if any. 
[8] Ml must be active for a minimum of two clock cycles to 

reset the PIO. 
[9] Z80B PIO numbers are preliminary and subject to change. 
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Absolute Voltages on all inputs and outputs 

Maximum with respect to GND -0.3 V to +7.0 V 

Ratings Operating Ambient 

Temperature As Specified in 

Ordering Information 

Storage Temperature -65 °C to +150°C 



Stresses greater than those listed under Absolute Maxi- 
mum Ratings may cause permanent damage to the device. 
This is a stress rating only; operation of the device at any 
condition above those indicated in the operational sections 
of these specifications is not implied. Exposure to absolute 
maximum rating conditions for extended periods may affect 
device reliability. 



Test The characteristics below apply for the 

Conditions following standard test conditions, unless 

otherwise noted. All voltages are referenced to 
GND (0 V). Positive current flows into the 
referenced pin. Available operating 
temperature ranges are: 

■ 0° to +70°C, 

+ 4.75 V < V cc ^ +5.25 V 

■ -40°Cto +85°C, 

+ 4.75 V <; V cc < +5.25 V 

■ -55° to +125°C, 

+ 4.75 V < V cc < +5.5 V 
The product number for each operating 
temperature range may be found in the 



Ordering Information section. 

All ac parameters assume a load capacitance 
of 100 pF max. Timing references between two 
output signals assume a load difference of 
50 pF max. 




DC 

Charac- 
teristics 


Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 


VlLC 


Clock Input Low Voltage 


-0.3 


+ 0.45 


V 






VlHC 


Clock. Input High Voltage 


Vcc-0-6 


+ 5.5 


V 






V,L 


Input Low Voltage 


-0.3 


+ 0.8 


V 






V,H 


Input High Voltage 


+ 2.0 


+ 5.5 


V 






Vol 

VqH 


Output Low Voltage 
Output High Voltage 


+ 2.4 


+ 0.4 


V 
V 


I OL = 2.0 mA 
Iqh = -250 /tA 




lu 


Input Leakage Current 


-10.0 


+ 10.0 


I* 


0<Vin<V C c 




h 


3-State Output/Data Bus Input Leakage Current 


-10.0 


+ 10.0 


M 


0<Vin<Vcc 




he 


Power Supply Current 




100.0 


mA 


Voh = 1-5V 




JOHD 


Darlington Drive Current 


-1.5 


3.8 


mA 


Rext = 390 fl 




Over specified temperature and voltage range. 










Capacitanc 


e Symbol 


Parameter 


Min 


Max 


Unit 


Test Condition 




C 

C OUT 


Clock Capacitance 
Input Capacitance 
Output Capacitance 




10 
5 
10 


pF 
pF 
P F 


Unmeasured 
pins returned 
to ground 



Over speciiied temperature range; f = 1MH Z 



56 



11.3 Appendex C - Z80A CTC 



Z8430 

Z80® CTC Counter/ 

Timer Circuit 




Zilog 



Product 



March 1981 



Features D Four independently programmable 

counter/timer channels, each with a 
readable downcounter and a selectable 
16 or 256 prescaler. Downcounters are 
reloaded automatically at zero count. 

□ Three channels have Zero Count/Timeout 
outputs capable of driving Darlington 
transistors. 



Selectable positive or negative trigger 
initiates timer operation. 

Standard Z-80 Family daisy-chain interrupt 
structure provides fully vectored, prioritized 
interrupts without external logic. The CTC 
may also be used as an interrupt controller. 

Interfaces directly to the Z-80 CPU or— for 
baud rate generation — to the Z-80 SIO. 
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General The Z-80 CTC four-channel counter/timer 

Description can be programmed by system software for a 
broad range of counting and timing applica- 
tions. The four independently programmable 
channels of the Z-80 CTC satisfy common 
microcomputer system reguirements for event 
counting, interrupt and interval timing, and 
general clock rate generation. 

System design is simplified because the CTC 
connects directly to both the Z-80 CPU and the 
Z-80 SIO with no additional logic. In larger 
systems, address decoders and buffers may be 
reguired. 

Programming the CTC is straightforward: 



each channel is programmed with two bytes; a 
third is necessary when interrupts are enabled. 
Once started, the CTC counts down, reloads 
its time constant automatically, and resumes 
counting. Software timing loops are completely 
eliminated. Interrupt processing is simplified 
because only one vector need be specified; the 
CTC internally generates a unigue vector for 
each channel. 

The Z-80 CTC reguires a single +5 V power 
supply and the standard Z-80 single-phase 
system clock. It is fabricated with n-channel 
silicon-gate depletion-load technology, and 
packaged in a 28-pin plastic or ceramic DIP. 
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Functional The Z-80 CTC has four independent counter/ 

Description timer channels. Each channel is individually 
programmed with two words: a control word 
and a time-constant word. The control word 
selects the operating mode (counter or timer), 
enables or disables the channel interrupt, and 
selects certain other operating parameters. If 
the timing mode is selected, the control word 
also sets a prescaler, which divides the system 
clock by either 16 or 256. The time-constant 
word is a value from 1 to 256. 

During operation, the individual counter 
channel counts down from the preset time con- 
stant value. In counter mode operation the 
counter decrements on each of the CLK/TRG 
input pulses until zero count is reached. Each 
decrement is synchronized by the system 
clock. For counts greater than 256, more than 
one counter can be cascaded. At zero count, 
the down-counter is automatically reset with 
the time constant value. 

The timer mode determines time intervals as 
small as 4 us (Z-80A) or 6.4 us (Z-80) without 
additional logic or software timing loops. Time 
intervals are generated by dividing the system 
clock with a prescaler that decrements 



a preset down-counter. 

Thus, the time interval is an integral mul- 
tiple of the clock period, the prescaler value 
(16 or 256) and the time constant that is preset 
in the down-counter. A timer is triggered auto- 
matically when its time constant value is pro- 
grammed, or by an external CLK/TRG input. 

Three channels have two outputs that occur 
at zero count. The first output is a zero- 
count/timeout pulse at the ZC/TO output. The 
fourth channel (Channel 3) does not have a 
ZC/TO output; interrupt reguest is the only 
output available from Channel 3. 

Th e second output is Interrupt Request 
(INT), which occurs if the channel has its 
interrupt enabled during programming. When 
the Z-80 CPU acknowledges Interrupt Request, 
the Z-80 CTC places an interrupt vector on the 
data bus. 

The four channels of the Z-80 CTC are fully 
prioritized and fit into four contiguous slots in 
a standard Z-80 daisy-chain interrupt struc- 
ture. Channel is the highest priority and 
Channel 3 the lowest. Interrupts can be 
individually enabled (or disabled) for each of 
the four channels. 



Architecture The CTC has four major elements, as shown 

in Figure 3. 

■ CPU bus I/O 

■ Channel control logic 

■ Interrupt logic 

■ Counter/timer circuits 

CPU Bus I/O. The CPU bus I/O circuit 
decodes the address inputs, and interfaces the 
CPU data and control signals to the CTC for 
distribution on the internal bus. 



Internal Control Logic. The CTC internal 
control logic controls overall chip operating 
functions such as the chip enable, reset, and 
read/write logic. 

Interrupt Logic. The interrupt control logic 
ensures that the CTC interrupts interface prop- 
erly with the Z-80 CPU interrupt system. The 
logic controls the interrupt priority of the CTC 
as a function of the IEI signal. If IEI is High, 
the CTC has priority. During interrupt 
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Figure 3. Functional Block Diagram 
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Architecture processing, the interrupt logic holds IEO Low, 
(Continued) which inhibits the interrupt operation on lower 
priority devices. If the IEI input goes Low, 
priority is relinquished and the interrupt logic 
drives IEO Low. 

If a channel is programmed to request an 
interrupt, the interrupt logic driv es IE O Low at 
the zero count, and generates an INT signal to 
the Z-80 CPU. When the Z-80CPU r espond s 
with interrupt acknowledge (Ml and IORQ), 
then the interrupt logic arbitrates the CTC 
internal priorities, and the interrupt control 
logic places a unique interrupt vector on the 
data bus. 

If an interrupt is pending, the interrupt logic 
holds IEO Low. When the Z-80 CPU issues a 
Return From Interrupt (RETI) instruction, each 
peripheral device decodes the first byte 
(EDj6). If the device has a pending interrupt, 
it raises IEO (High) for one Ml cycle. This 
ensures that all lower priority devices can 
decode the entire RETI instruction and reset 
properly. 
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Figure 4. Counter/Timer Block Diagram 

Counter/ Timer Circuits. The CTC has four 
independent counter/timer circuits, each con- 
taining the logic shown in Figure 4. 

Channel Control Logic. The channel control 
logic receives the 8-bit channel control word 
when the counter/timer channel is pro- 
grammed. The channel control logic decodes 



the control word and sets the following 
operating conditions: 

a Interrupt enable (or disable) 

O Operating mode (timer or counter) 

B Timer mode prescaler factor (16 or 256) 

B Active slope for CLK/TRG input 

B Timer mode trigger (automatic or CLK/TRG 

input) 
B Time constant data word to follow 
B Software reset 

Time Constant Register. When the counter/ 
timer channel is programmed, the time con- 
stant register receives and stores an 8-bit time 
constant value, which can be anywhere from 1 
to 256 (0 = 256). This constant is automatic- 
ally loaded into the down-counter when the 
counter/timer channel is initialized, and subse- 
quently after each zero count. 

Prescaler. The prescaler, which is used only 
in timer mode, divides the system clock fre- 
quency by a factor of either 16 or 256. The 
prescaler output clocks the down-counter dur- 
ing timer operation. The effect of the prescaler 
on the down-counter is a multiplication of the 
system clock period by 16 or 256. The pre- 
scaler factor is programmed by bit 5 of the 
channel control word. 

Down-Counter. Prior to each count cycle, the 
down-counter is loaded with the time constant 
register contents. The counter is then 
decremented one of two ways, depending on 
operating mode: 

□ By the prescaler output (timer mode) 
a By the trigger pulses into the CLK/TRG 
input (counter mode) 

Without disturbing the down-count, the Z-80 
CPU can read the count remaining at any time 
by performing an I/O read operation at the 
port address assigned to the CTC channel. 
When the down-counter reaches the zero 
count, the ZC/TO output generates a positive- 
going pulse. When the interrupt is enabled, 
zero co unt also triggers an interrupt request 
signal (INT) from the interrupt logic. 



N 

00 

o 
o 

H 



61 



Programming Each Z-80 CTC channel must be pro- 
grammed prior to operation. Programming 
consists of writing two words to the I/O port 
that corresponds to the desired channel. The 
first word is a control word that selects the 
operating mode and other parameters; the 
second word is a time constant, which is a 
binary data word with a value from 1 to 256. A 
time constant word must be preceded by a 
channel control word. 

After initialization, channels may be 
reprogrammed at any time. If updated control 
and time constant words are written to a chan- 
nel during the count operation, the count con- 
tinues to zero before the new time constant is 
loaded into the counter. 

If the interrupt on any Z-80 CTC channel is 
enabled, the programming procedure should 
also include an interrupt vector. Only one vec- 
tor is reguired for all four channels, because 
the interrupt logic automatically modifies the 
vector for the channel requesting service. 

A control word is identified by a 1 in bit 0. 
A in bit 2 indicates a time constant word is to 
follow. Interrupt vectors are always addressed 
to Channel 0, and identified by a in bit 0. 

Addressing. During programming, channels 
are addressed with the channel select pins CSi 
and CS2. A 2-bit binary code selects the 
appropriate channel as shown in the following 
table. 

Channel CSi CSq 












1 
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Reset. The CTC has both hardware and soft- 
ware resets. The hardware reset terminates all 
down-counts and disables all CTC interrupts 
by resetting the interrupt bits in the control 
registers. In addition, the ZC/TO and Interrupt 
outputs go inactive, IEO reflects IEI, and 



D0-D7 go to the high- impedance state. All 
channels must be completely reprogrammed 
after a hardware reset. 

The software reset is controlled by bit 1 in 
the channel control word. When a channel 
receives a software reset, it stops counting. 
When a software reset is used, the other bits in 
the control word also change the contents of 
the channel control register. After a software 
reset a new time constant word must be written 
to the same channel. 

If the channel control word has both bits Dj 
and D2 set to 1 , the addressed channel stops 
operating, pending a new time constant word. 
The channel is ready to resume after the new 
constant is programmed. In timer mode, if 
D3 = 0, operation is triggered automatically 
when the time constant word is loaded. 

Channel Control Word Programming. The 

channel control word is shown in Figure 5. It 
sets the modes and parameters described 
below. 

Interrupt Enable. D7 en ables the interrupt, so 
that an interrupt output (INT) is generated at 
zero count. Interrupts may be programmed in 
either mode and may be enabled or disabled 
at any time. 

Operating Mode. D6 selects either timer or 
counter mode. 

Prescaler Factor. (Timer Mode Only). D5 

selects factor — either 16 or 256. 

Trigger Slope. D4 selects the active edge or 
slope of the CLK/TRG input pulses. Note that 
reprogramming the CLK/TRG slope during 
operation is equivalent to issuing an active 
edge. If the trigger slope is changed by a con- 
trol word update while a channel is pending 
operation in timer mode, the result is the same 
as a CLK/TRG pulse and the timer starts. 
Similarly, if the channel is in counter mode, 
the counter decrements. 



INTERRUPT 

1 ENABLES INTERRUPT 
DISABLES INTERRUPT 

MODE 

SELECTS TIMER MODE 
1 SELECTS COUNTER MODE 

PRESCALER VALUE* 

1 = VALUE OF 256 
= VALUE OF 16 

CLKJTRQ EOOE SELECTION 

SELECTS FALLING EDGE 

1 SELECTS RISING EDGE 



CONTROL OR VECTOR 

= VECTOR 

1 = CONTROL WORD 

RESET 

= CONTINUED OPERATION 

1 = SOFTWARE RESET 

TIME CONSTANT 

= NO TIME CONSTANT FOLLOWS 

1 = TIME CONSTANT FOLLOWS 

TIMER TRIQOER* 

= AUTOMATIC I RIGGER WHEN 

TIME CONSTANT IS LOADED 

1 = CLK/TRG PULSE STARTS TIMER 

'TIMER MODE ONLY 



Figure 5. Channel Control Word 
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Programming Trigger Mode (Timer Mode Only). D3 selects 
(Continued) the trigger mode for timer operation. When D3 
is reset to 0, the timer is triggered automatic- 
ally. The time constant word is programmed 
during an I/O write operation, which takes one 
machine cycle. At the end of the write opera- 
tion there is a setup delay of one clock period. 
The timer starts automatically (decrements) on 
the rising edge of the second clock pulse (T2) 
of the machine cycle following the write opera- 
tion. Once started, the timer runs contin- 
uously. At zero count the timer reloads 
automatically and continues counting without 
interruption or delay, until stopped by a reset. 

When D3 is set to 1 , the timer is triggered 
externally through the CLK/TRG input. The 
time constant word is programmed during an 
I/O write operation, which takes one machine 
cycle. The timer is ready for operation on the 
rising edge of the second clock pulse (T2) of 
the following machine cycle. Note that the first 
timer decrement follows the active edge of the 
CLK/TRG pulse by a delay time of one clock 
cycle if a minimum setup time to the rising 
edge of clock is met. If this minimum is not 
met, the delay is extended by another clock 
period. Consequently, for immediate trigger- 
ing, the CLK/TRG input must precede T2 by 
one clock cycle plus its minimum setup time. If 
the minimum time is not met, the timer will 
start on the third clock cycle (T3). 

Once started the timer operates contin- 
uously, without interruption or delay, until 
stopped by a reset. 

Time Constant to Follow. A 1 in D2 indicates 
that the next word addressed to the selected 
channel is a time constant data word for the 
time constant register. The time constant word 
may be written at any time. 

A in D2 indicates no time constant word is 
to follow. This is ordinarily used when the 
channel is already in operation and the new 
channel control word is an update. A channel 
will not operate without a time constant value. 
The only way to write a time constant value is 
to write a control word with D2 set. 



Software Reset. Setting Dj to 1 causes a soft- 
ware reset, which is described in the Reset 
section. 

Control Word. Setting Do to 1 identifies the 
word as a control word. 

Time Constant Programming. Before a chan- 
nel can start counting it must receive a time 
constant word from the CPU. During program- 
ming or reprogramming, a channel control 
word in which bit 2 is set must precede the 
time constant word to indicate that the next 
word is a time constant. The time constant 
word can be any value from 1 to 256 (Figure 
6). Note that 00i6 is interpreted as 256. 

In timer mode, the time interval is controlled 
by three factors: 

D The system clock period (<£) 

B The prescaler factor (P), which multiplies 
the interval by either 16 or 256 

ED The time constant (T), which is programmed 
into the time constant register 

Consequently, the time interval is the pro- 
duct of <$> x P x T. The minimum timer resolu- 
tion is 16 x </> (4 us with a 4 MHz clock). The 
maximum timer interval is 256 x <f> x 256 (16.4 ms 
with a 4 MHz clock). For longer intervals 
timers may be cascaded. 

Interrupt Vector Programming. If the Z-80 
CTC has one or more interrupts enabled, it 
can supply interrupt vectors to the Z-80 CPU. 
To do so, the Z-80 CTC must be pre-pro- 
grammed with the most-significant five bits of 
the interrupt vector. Programming consists of 
writing a vector word to the I/O port cor- 
responding to the Z-80 CTC Channel 0. Note 
that Do of the vector word is always zero, to 
distinguish the vector from a channel control 
word. Dj and D2 are not used in programming 
the vector word. These bits are supplied by 
the interrupt logic to identify the channel 
requesting interrupt service with a unique 
interrupt vector (Figure 7). Channel has the 
highest priority. 
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Pin CE. Chip Enable (input, active Low). When 

Description enabled the CTC accepts control words, inter- 
rupt vectors, or time constant data words from 
the data bus during an I/O write cycle; or 
transmits the contents of the down-counter to 
the CPU during an I/O read cycle. In most 
applications this signal is decoded from the 
eight least significant bits of the address bus 
for any of the four I/O port addresses that are 
mapped to the four counter-timer channels. 

CLK. System Clock (input). Standard single- 
phase Z-80 system clock. 

CLK/TRG0-CLK/TRG3. External Clock/Timer 
Trigger (input, user-selectable active High or 
Low). Four pins corresponding to the four Z-80 
CTC channels. In counter mode, every active 
edge on this pin decrements the down-counter. 
In timer mode, an active edge starts the timer. 

CS0-CS1. Channel Select (inputs active High). 
Two-bit binary address code selects one of the 
four CTC channels for an I/O write or read 
(usually connected to Ao and A\). 

D0-D7. System Data Bus (bidirectional, 
3-state). Transfers all data and commands 
between the Z-80 CPU and the Z-80 CTC. 




IEI. Interrupt Enable In (input, active High). 
A High indicates that no other interrupting 
devices of higher priority in the daisy chain 
are being serviced by the Z-80 CPU. 

IEO. Interrupt Enable Out (output, active 
High). High only if IEI is High and the Z-80 
CPU is not servicing an interrupt from any 
Z-80 CTC channel. IEO blocks lower priority 
devices from interrupting while a higher 
priority -interrupting device is being serviced. 

INT. Interrupt Bequest (output, open drain, 
active Low). Low when any Z-80 CTC channel 
that has been programmed to enable interrupts 
has a zero-count condition in its down-counter. 



IORQ. Input/Output Bequest (input from CPU, 
active Low). Used with CE and RD to transfer 
data and channel control words between the 
Z-80 C PU an d the Z-80 CTC. During_a_write 
cycle, IORQ and CE are active and RD 
inactive. The Z-80 CTC does not receive a 
specific write signal; rather, it internally 
gen erates its own from the i nverse of an ac tive 
RD signal. In a read cycle, IORQ, CE and RD 
are active; the contents of the down - counter 
are read by the Z-80 CPU. If IORQ and Ml are 
both true, the CPU is acknowledging an inter- 
rupt request, and the highest priority inter- 
rupting channel places its interrupt vector on 
the Z-80 data bus. 

Ml. Machine Cycle One (i nput fr om CPU, 
active Low). When Ml and IORQ are active, 
the Z-80 CPU is acknowledging an interrupt. 
The Z-80 CTC then places an interrupt vector 
on the data bus if it has highest priorit y, a nd if 
a channel has requested an interrupt (INT). 

RD. Bead Cycle Status (i nput, a ctiv e Lo w). 
Used in conjunction with IORQ and CE to 
transfer data and channel control words 
between the Z-80 CPU and the Z-80 CTC. 



RESET. Beset (input active Low). Terminates 
all down-counts and disables all interrupts by 
resetting the interrupt bits in all control 
registers; the ZC/TO and the Interrupt outputs 
go inactive; IEO reflects IEI; D0-D7 go to the 
high-impedance state. 

ZC/TO -ZC/TO 2 . Zero Count/Timeout (output, 
active High). Three ZC/TO pins corresponding 
to Z-80 CTC channels 2 through (Channel 3 
has no ZC/TO pin). In both counter and timer 
modes the output is an active High pulse when 
the down-counter decrements to zero. 



Figure 8. A Typical Z-80 Environment 



64 



2041-0156 



Timing Read Cycle Timing. Figure 9 shows read 

cycle timing. This cycle reads the contents of a 
down-counter without disturbing the count. 
During clock cycle T2, the Z-80 CPU initiates a 
read cycle by dr iving the following inputs 
Low: RD, IORQ, and CE. A 2-bit binary code 
at inputs C§i and CSo selects the channel to 
be read. Ml must be High to distinguish this 
cycle from an interrupt acknowledge. No addi- 
tional wait states are allowed. 



latched into the appropriate register with the 
rising edge of clock cycle Ty/A- No additional 
wait states are allowed. 




Figure 11. Timer Mode Timing 
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Figure 9. Read Cycle Timing 

Write Cycle Timing. Figure 10 shows write 
cycle timing for loading control, time constant 
or vector words. 

The CTC does not have a write signal input, 
so it generates one internally when the read 
(RD) i nput is H igh during Tj. Dur ing T2 
IORQ and CE inputs are Low. Ml must be 
High to distinguish a write cycle from an inter- 
rupt acknowledge. A 2-bit binary code at 
inputs CSi and CSo selects the channel to be 
addressed, and the word being written is 
placed on the Z-80 data bus. The data word is 



Timer Operation. In the timer mode, a 
CLK/TRG pulse input starts the timer (Figure 
11) on the second succeeding rising edge of 
CLK. The trigger pulse is asynchronous, and it 
must have a minimum width. A minimum lead 
time (210 ns) is required between the active 
edge of the CLK/TRG and the next rising edge 
of CLK to enable the prescaler on the follow- 
ing clock edge. If the CLK/TRG edge occurs 
closer than this, the initiation of the timer 
function is delayed one clock cycle. This cor- 
responds to the startup timing discussed in the 
programming section. The timer can also be 
started automatically if so programmed by the 
channel control word. 
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Figure 12. Counter Mode Timing 
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Figure 10. Write Cycle Timing 



Counter Operation. In the counter mode, the 
CLK/TRG pulse input decrements the down- 
counter. The trigger is asynchronous, but the 
count is synchronized with CLK. For the 
decrement to occur on the next rising edge of 
CLK, the trigger edge must precede CLK by a 
minimum lead time as shown in Figure 12. If 
the lead time is less than specified, the count 
is delayed by one clock cycle. The trigger 
pulse must have a minimum width, and the 
trigger period must be at least twice the clock 
period. 

The ZC/TO output occurs immediately after 
zero count, and follows the rising CLK edge. 
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Interrupt The Z-80 CTC follows the Z-80 system inter- 

Operation rupt protocol for nested priority interrupts and 

return from interrupt, wherein the interrupt 
priority of a peripheral is determined by its 
location in a daisy chain. Two lines — IEI and 
IEO — in the CTC connect it to the system daisy 
chain. The device closest to the + 5 V supply 
has the highest priority (Figure 13). For addi- 
tional information on the Z-80 interrupt struc- 
ture, refer to the Z-80 CPU Product Specifica- 
tion and the Z-80 CPU Technical Manual. 
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Figure 13. Daisy-Chain Interrupt Priorities 

Within the Z-80 CTC, interrupt priority is 
predetermined by channel number: Channel 
has the highest priority, and Channel 3 the 
lowest. If a device or channel is being serviced 
with an interrupt routine, it cannot be inter- 
rupted by a device or channel with lower 
priority until service is complete. Higher 
priority devices or channels may interrupt the 
servicing of lower priority devices or channels. 

A Z-80 CTC channel may be programmed to 
reguest an interrupt every time its down- 
counter reaches zero. Note that the CPU must 
be programmed for interrupt mode 2. Some 
time after the interrupt reguest, the CPU sends 
an interrupt acknowledge. The CTC interrupt 
control logic determines the highest priority 
channel that is requesting an interrupt. Then, 
if the CTC IEI input is High (indicating that it 
has priority within the system daisy chain) it 
places an 8-bit interrupt vector on the system 
data bus. The high-order five bits of this vector 



were written to the CTC during the program- 
ming process; the next two bits are provided 
by the CTC interrupt control logic as a binary 
code that identifies the highest priority chan- 
nel requesting an interrupt; the low-order bit 
is always zero. 

Interrupt Acknowledge Timing. Figure 14 
shows interrupt acknowledge timing. After an 
interrupt request, the Z-80 CPU s ends an inter- 
rupt acknowledge (Ml and IORQ). All chan- 
nels are inhibited from changing their inter- 
rupt request status when Ml i s activ e — about 
two clock cycles earlier than IORQ. RD is 
High to distinguish this cycle from an instruc- 
tion fetch. 

The CTC interrupt logic determines the 
highest priority channel reguesting an inter- 
rupt. If the CTC interrupt enable input (IEI) is 
High, the highest priority interrupting channel 
within the CTC pla ces its interrupt vector on 
the data bus when IORQ goes Low. Two wait 
states (Twa) are automatically inserted at this 
time to allow the daisy chain to stabilize. Addi- 
tional wait states may be added. 

Return from Interrupt Timing. At the end of 

an interrupt service routine the RETI (Return 
From Interrupt) instruction initializes the daisy 
chain enable lines for proper control of nested 
priority interrupt handling. The CTC decodes 
the 2-byte RETI code internally and determines 
whether it is intended for a channel being ser- 
viced. Figure 15 shows RETI timing. 

If several Z-80 peripherals are in the daisy 
chain, IEI settles active (High) on the chip 
currently being serviced when the opcode 
EDj6 is decoded. If the following opcode is 
4D]6, the peripheral being serviced is released 
and its IEO becomes active. Additional wait 
states are allowed. 
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Figure 14. Interrupt Acknowledge Timing 



Figure 15. Return From Interrupt Timing 
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Appendex D - Floppy Disk controller 
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FD 179X-02 Floppy Disk Formatter/Controller Family 



FEATURES 

• TWO VFO CONTROL SIGNALS 

• SOFT SECTOR FORMAT COMPATIBILITY 

• AUTOMATIC TRACK SEEK WITH 
VERIFICATION 

• ACCOMMODATES SINGLE AND DOUBLE 
DENSITY FORMATS 

IBM 3740 Single Density (FM) 

IBM System 34 Double Density (MFM) 

• READ MODE 

Single/Multiple Sector Read with Automatic 

Search or Entire Track Read 
Selectable 128 Byte or Variable length Sector 

• WRITE MODE 

Single/Multiple Sector Write with Automatic 

Sector Search 
Entire Track Write for Diskette Formatting 

• SYSTEM COMPATIBILITY 

Double Buffering of Data 8 Bit Bi-Directional 

Bus for Data, Control and Status 
DMA or Programmed Data Transfers 
All Inputs and Outputs are TTL Compatible 
On-Chip Track and Sector Registers/Comprehensive 

Status Information 



PROGRAMMABLE CONTROLS 
Selectable Track to Track Stepping Time 
Side Select Compare 
WRITE PRECOMPENSATION 
WINDOW EXTENSION 
INCORPORATES ENCODING/DECODING 

AND ADDRESS MARK CIRCUITRY 
FD1792/4 IS SINGLE DENSITY ONLY 
FD1795/7 HAS A SIDE SELECT OUTPUT 

179X-02 FAMILY CHARACTERISTICS 



FEATURES 


1791 


1793 


1795 


1797 


Single Density (FM) 


X 


X 


X 


X 


Double Density (MFM) 


X 


X 


X 


X 


True Data Bus 




X 




X 


Inverted Data Bus 


X 




X 




Write Precomp 


X 


X 


X 


X 


Side Selection Output 






X 


X 




APPLICATIONS 

FLOPPY DISK DRIVE INTERFACE 

SINGLE OR MULTIPLE DRIVE CONTROLLER/ 

FORMATTER 
NEW MINI-FLOPPY CONTROLLER 




c 



> 




PIN CONNECTIONS 



I 



FLOPPY DISK 
CONTROLLER 
FORMATTER 



VSS VOD VCC 



LAT E 
EARLY 



i- 



FD179X SYSTEM BLOCK DIAGRAM 



GENERAL DESCRIPTION 

The FD179X are MOS LSI devices which perform the 
functions of a Floppy Disk Formatter/Controller in 
a single chip implementation. The FD179X, which 
can be considered the end result of both the FD1771 
and FD1781 designs, is IBM 3740 compatible in 
single density mode (FM) and System 34 compatible 
in Double Density Mode (MFM). The FD179X con- 
tains all the features of its predecessor the FD1771, 
plus the added features necessary to read/write and 
format a double density diskette. These include ad- 
dress mark detection, FM and MFM encode and de- 
code logic, window extension, and write precompen- 
sation. In order to maintain compatibility, the FD1771, 
FD1781, and FD179X designs were made as close as 
possible with the computer interface, instruction set, 
and I/O registers being identical. Also, head load 

PIN OUTS 



control is identical. In each case, the actual pin as- 
signments vary by only a few pins from any one to 
another. 

The processor interface consists of an 8-bit bi- 
directional bus for data, status, and control word 
transfers. The FD179X is set up to operate on a mul- 
tiplexed bus with other bus-oriented devices. 

The FD179X is fabricated in N-channel Silicon Gate 
MOS technology and is TTL compatible on all inputs 
and outputs. The 1793 is identical to the 1791 except 
the DAL lines are TRUE for systems that utilize true 
data busses. 

The 1795/7 has a side select output for controlling dou- 
ble sided drives, and the 1792 and 1794 are "Single 
Density Only" versions of the 1791 and 1793. On these 
devices, DDEN must be left open. 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


1 
19 


NO CONNECTION 


NC 
MR 


Pin 1 is internally connected to a back bias 
generator and must be left open by the user. 

A logic low on this input resets the device and 
loads HEX 03 into the command register. The Not 
Ready (Status Bit 7) is reset during MR ACTIVE. 
When MR is brought to a logic high a RESTORE 
Command is executed, regardless of the state of 
the Ready signal from the drive. Also, HEX 01 is 
loaded into sector register. 


MASTER RESET 


20 


POWER SUPPLIES 


Vss 


Ground 


21 




Vcc 


+5V ±5% 


40 




Vod 


+ 12V±5% 


COMPUTER 
2 

3 

4 


INTERFACE: 


WE 
CS 
RE 


A logic low on this input gates data on the DAL 
into the selected register when CS is low. 

A logic low on this input selects the chip and ena- 
bles computer communication with the device. 

A logic low on this input controls the placement_of 
data from a selected register on the DAL when CS 
is low. 


WRITE ENABLE 


CHIP SELECT 


READ ENABLE 


5,6 


REGISTER SELECT 
LINES 


A0, A1 


These inputs select the register to receive/ 
transfer data on the DAL lines under RE and WE 
control: 

A1 A0 RE WE 


7-14 




DALC-DAL7 


Status Reg Command Reg 

1 Track Reg Track Reg 

1 Sector Reg Sector Reg 
1 1 Data Reg Data Reg 

Eight bit inverted Bidirectional bus used for trans- 
fer of data, control, and status. This bus jsreceiver 
enabled by WE or transmitter enabled by RE. 


DATA ACCESS LINES 


24 


CLOCK 


CLK 


This input requires a free-running square wave 
clock for internal timing reference, 2 MHz for 8" 
drives, 1 MHz for mini-drives. 



PIN 
NUMBER 


PIN NAME 


SYMBOL 


FUNCTION 


38 


DATA REQUEST 


DRQ 


This open drain output indicates that the DR' con- 
tains assembled data in Read operations, or the 
DR is empty in Write operations. This signal is 
reset when serviced by the computer through 
reading or loading the DR in Read or Write opera- 
tions, respectively. Use 1 0K pull-up resistor to +5. 


39 INTERRUPT 
REQUEST 

FLOPPY DISK INTERFACE: 


INTRQ 


This open drain output is set at the completion of any 
command and is reset when the STATUS register is 
read or the command register is written to. Use 10K 
pull-up resistor to +5. 


15 


STEP 


STEP 


The step output contains a pulse for each step. 


16 


DIRECTION 


DIRC 


Direction Output is active high when stepping in, 
active low when stepping out. 


17 


EARLY 


EARLY 


Indicates that the WRITE DATA pulse occurring 
while Early is active (high) should be shifted early 
for write precompensation. 


18 


LATE 


LATE 


Indicates that the write data pulse occurring while 
Late is active (high) should be shifted late for write 
precompensation. 


22 


TEST 


TEST 


This input is used for testing purposes only and 
should be tied to +5V or left open by the user un- 
less interfacing to voice coil actuated motors. 


23 


HEAD LOAD TIMING 


HLT 


When a logic high is found on the HLT input the 
head is assumed to be engaged. 


25 


READ GATE (1791/3) 


RG 


A high level on this output indicates to the data 
separator circuitry that a field of zeros (or ones) 
has been encountered, and is used for synchroni- 
zation. 


25 


SIDE SELECT OUTPUT 
(1795, 1797) 


SSO 


The logic level of the Side Select Output is directly 
controlled by the 'S' flag in Type II or III commands. 
When S = 1, SSO is set to a logic 1. When S = 0, 
SSO is set to a logic 0. The Side Select Output is only 
updated at the beginning of a Type II or III command. 
It is forced to a logic upon a MASTER RESET 
condition. 


26 
27 


READ CLOCK 


RCLK 


A nominal square-wave clock signal derived from 
the data stream must be provided to this input. 
Phasing (i.e. RCLK transitions) relative to RAW 
READ is important but polarity (RCLK high or low) 
is not. 

The data input signal directly from the drive. This 
input shall be a negative pulse for each recorded 
flux transition. 


RAW READ 


RAW READ 


28 


HEAD LOAD 


HLD 


The HLD output controls the loading of the 
Read-Write head against the media. 


29 


TRACK GREATER 
THAN 43 


TG43 


This output informs the drive that the Read/Write 
head is positioned between tracks 44-76. This output 
is valid only during Read and Write Commands. 




WRITE GATE 


WG 


This output is made valid before writing is to be 
performed on the diskette. 

: 





PIN 
NUMBER 



31 



32 



33 



34 
35 
36 

37 



PIN NAME 



WRITE DATA 



READY 



WRITE FAULT 
VFO ENABLE 



TRACK 00 



INDEX PULSE 



WRITE PROTECT 



DOUBLE DENSITY 



SYMBOL 



WD 



READY 



WF/VFOE 



TR00 

ip 

WPRT 
DDEN 



FUNCTION 



A 250 ns (MFM) or 500 ns (FM) pulse per flux 
transition. WD contains the unique Address marks 
as well as data and clock in both FM and MFM 
formats. 

This input indicates disk readiness and is sampled 
for a logic high before Read or Write commands 
are performed. If Ready is low the Read or Write 
operation is not performed and an interrupt is 
generated. Type I operations are performed re- 
gardless of the state of Ready. The Ready input 
appears in inverted format as Status Register bit 
7. 

This is a bi-directional signal used to signify writing 
faults at the drive, and to enable the external PLO 
data separator. When WG = 1, Pin 33 functions as 
a WF input. If WF = 0, any write command will im- 
mediately be terminated. When WG = 0, Pin 33 func- 
tions as a VFOE output. VFOE will go low during a 
read operation after the head has loaded and settled 
(HLT = 1). On the 1795/7, it will remain low until the 
last bit of the second CRC byte in the ID field. VFOE 
will then go high until 8 bytes (MFM) or 4 bytes (FM) 
before the Address Mark. It will then go active until 
the last bit of the second CRC byte of the Data Field. 
On the 1791/3, VFOE will remain low until the end of 
the Data Field. 

This input informs the FD179X that the Read/Write 
head is positioned over Track 00. 

This input informs the FD179X when the index hole 
is encountered on the diskette. 

This input is sampled whenever a Write Command 
is received. A logic low terminates the command 
and sets the Write Protect Status bit. 

This pin selects either s ingle or double density op- 
eration. When D DEN = 0, double density is 
selected. When DDEN = 1, single density is 
selected. This line must be left open on the 1792/4 



ORGANIZATION 

The Floppy Disk Formatter block diagram is illus- 
trated on page 5. The primary sections include the 
parallel processor interface and the Floppy Disk inter- 
face. 

Data Shift Register— This 8-bit regist er assemble s 
serial data from the Read Data input (RAW READ) 
during Read operations and transfers serial data to 
the Write Data output during Write operations. 
Data Register — This 8-bit register is used as a hold- 
ing register during Disk Read and Write operations. 
In Disk Read operations the assembled data byte is 
transferred in parallel to the Data Register from the 
Data Shift Register. In Disk Write operations informa- 
tion is transferred in parallel from the Data Register 
to the Data Shift Register. 



When executing the Seek command the Data Regis- 
ter holds the address of the desired Track position. 
This register is loaded from the DAL and gated onto 
the DAL under processor control. 

Track Register— This 8-bit register holds the track 
number of the current Read/Write head position. It is 
incremented by one every time the head is stepped in 
(towards track 76) and decremented by one when the 
head is stepped out (towards track 00). The contents 
of the register are compared with the recorded track 
number in the ID field during disk Read, Write, and 
Verify operations. The Track Register can be loaded 
from or transferred to the DAL. This Register should 
not be loaded when the device is busy. 
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Sector Register (SR) — This 8-bit register holds the 
address of the desired sector position. The contents 
of the register are compared with the recorded sector 
number in the ID field during disk Read or Write op- 
erations. The Sector Register contents can be loaded 
from or transferred to the DAL. This register should 
not be loaded when the device is busy. 
Command Register (CR) — This 8-bit register holds 
the command presently being executed. This register 
should not be loaded when the device is busy unless 
the new command is a force interrupt. The command 
register can be loaded from the DAL, but not read 
onto the DAL. 

Status Register (STR) — This 8-bit register holds de- 
vice Status information. The meaning of the Status 
bits is a function of the type of command previously 
executed. This register can be read onto the DAL, 
but not loaded from the DAL. 
CRC Logic— This logic is used to check or to gener- 
ate the 16-bit Cyclic Redundancy Check (CRC). The 
polynomial is: G(x) = x 16 + x 12 + x s + 1. 



The CRC includes all information starting with the 
address mark and up to the CRC characters. The 
CRC register is preset to ones prior to data being 
shifted through the circuit. 

Arithmetic/Logic Unit (ALU)— The ALU is a serial 
comparator, incrementer, and decrementer and is 
used for register modification and comparisons with 
the disk recorded ID field. 

Timing and Control — All computer and Floppy Disk 
Interface controls are generated through this logic. 
The internal device timing is generated from an ex- 
ternal crystal clock. 

The FD1791/3 has two diff erent m odes o f opera tion 
according to the state of DDEN. When DDEN = 
double density (MFM) is assumed. When DDEN = 1, 
single density (FM) is assumed. 

AM Detector — The address mark detector detects 
ID, data and index address marks during read and 
write operations. 
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PROCESSOR INTERFACE 

The interface to the processor is acco mplished 
through the eight Data Acce ss Li nes (DAL) and as- 
sociated control signals. The DAL are used to trans- 
fer Data, Stat us, a nd Control words out of, or into the 
FD179X. The DAL are three state buffers that are en- 
abled as output drivers when Chip Select (CS) and 
Read Enable (RE) are active (low logic state) or act 
as input receivers when CS and Write Enable (WE) 
are active. 

When transfer of data with the Floppy Disk Controller 
is required by thehost processor, the device address 
is decoded and CS is made low. The address bits A1 
and AO, combined with the signals RE during a Read 
operation or WE during a Write operation are inter- 
preted as selecting the following registers: 

A1-A0 READ (RE) WRITE (WE) 

Status Register Command Register 

1 Track Register Track Register 

1 Sector Register Sector Register 
1 1 Data Register Data Register 

During Direct Memory Access (DMA) types of data 
transfers between the Data Register of the FD179X 
and the processor, the Data Request (DRQ) output is 
used in Data Transfer control. This signal also ap- 
pears as status bit 1 during Read and Write opera- 
tions. 

On Disk Read operations the Data Request is acti- 
vated (set high) when an assembled serial input byte 
is transferred in parallel to the Data Register. This bit 
is cleared when the Data Register is read by the pro- 
cessor. If the Data Register is read after one or more 
characters are lost, by having new data transferred 
into the register prior to processor readout, the Lost 
Data bit is set in the Status Register. The Read op- 
eration continues until the end of sector is reached. 
On Disk Write operations the data Request is acti- 
vated when the Data Register transfers its contents 
to the Data Shift Register, and requires a new data 
byte. It is reset when the Data Register is loaded 
with new data by the processor. If new data is not 
loaded at the time the next serial byte is required by 
the Floppy Disk, a byte of zeroes is written on the 
diskette and the Lost Data bit is set in the Status Re- 
gister. 

At the completion of every command an INTRO is 
generated. INTRO is reset by either reading the 
status register or by loading the command register 
with a new command. In addition, INTRO is gener- 
ated if a Force Interrupt command condition is met. 

FLOPPY DISK INTERFACE 

The 17 9X has two modes of operati on according to the 
state of DDEN (Pin 37). When ODER = 1 , single density 
is selected. In either case, the CLK input (Pin 24) is at 
2 MHz. However, when interfacing with the mini-floppy, 
the CLK input is set at 1 MHz for both single density and 
double density. When the clock is at 2 MHz, the stepping 
rates of 3, 6, 10, and 15 ms are obtainable. When CLK 
equals 1 MHz these times are doubled. 



HEAD POSITIONING 

Five commands cause positioning of the Read-Write 
head (see Command Section). The period of each 
positioning step is specified by the r field in bits 1 and 
of the command word. After the last directional 
step an additional 15 milliseconds of head settling 
time takes place if the Verify flag is set in Type I 
commands. Note t hat this time doubles to 30 ms for 
a 1 MHz clock. If TEST = 0, there is zero settling 
time. There is also a 15 ms head settling time if the E 
flag is set in any Type II or III command. 

The rates (shown in Table 1) can be applied to a 
Step-Direction Motor through the device interface. 

Step — A 2 (is (MFM) or 4 /zs (FM) pulse is provided 
as an output to the drive. For every step pulse is- 
sued, the drive moves one track location in a direc- 
tion determined by the direction output. 

Direction (DIRC) — The Direction signal is active high 
when stepping in and low when stepping out. The Di- 
rection signal is valid 12 fis before the first stepping 
pulse is generated. 

When a Seek, Step or Restore command is executed 
an optional verification of Read- Write head position 
can be performed by setting bit 2 (V = 1) in the 
command word to a logic 1. The verification operation 
begins at the end of the 15 millisecond settling time 
after the head is loaded against the media. The track 
number from the first encountered ID Field is com- 
pared against the contents of the Track Register. If 
the track numbers compare and the ID Field Cyclic 
Redundancy Check (CRC) is correct, the verify oper- 
ation is complete and an INTRO is generated with no 
errors. The FD179X must find an ID field with correct 
track number and correct CRC within 5 revolutions of 
the media; otherwise the seek error is set and an 
INTRO is generated. 

Table 1. STEPPING RATES 



CLK 


2 MHz 


2 MHz 


1 MHz 


1 MHz 


2 MHz 


1 MHz 


DDEN 





1 





1 


X 


X 


R1 R0 


TEST=1 


TEST = 1 


TEST=1 


TEST=1 


TEST=0 


TEST=0 





3 ms 


3 ms 


6 ms 


6 ms 


184ps 


368jiS 


1 


6 ms 


6 ms 


12 ms 


12 ms 


190ps 


380/iS 


1 


10 ms 


10 ms 


20 ms 


20 ms 


198fis 


396mS 


1 1 


15 ms 


15 ms 


30 ms 


30 ms 


208/is 


416/is 



The Head Load (HLD) output controls the movement 
of the read/write head against the media. HLD is ac- 
tivated at the beginning of a Type I command if the h 
flag is set (h = 1), at the end of the Type I command 
if the verify flag (V = 1), or upon receipt of any Type 
II or III command. Once HLD is active it remains ac- 
tive until either a Type I command is received with 
(h = and V = 0); or if the FD179X is in an idle state 
(non-busy) and 15 index pulses have occurred. 
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Head Load Timing (HLT) is an input to the FD179X 
which is used for the head engage time. When 
HLT = 1, the FD179X assumes the head is com- 
pletely engaged. The head engage time is typically 
30 to 100 ms depending on drive. The low to high 
transition on HLD is typically used to fire a one shot. 
The output of the one shot is then used for HLT and 
supplied as an input to the FD179X. 



HLD f- 






HLT (FROM ONE SHOT) 



HEAD LOAD TIMING 

When both HLD and HLT are true, the FD179X will 
then read from or write to the media. The "and" of 
HLD and HLT appears as a status bit in Type I 
status. 

In summary for the Type I commands: if h = and 
V = 0, HLD is reset. If h = 1 and V = 0, HLD is set at the 
beginning of the command and HLT is not sampled nor 
is there an internal 15 ms delay. If h = and V = 1, 
HLD is set near the end of the command, an internal 
15 ms occurs, and the FD179X waits for HLT to be 
true. If h = 1 and V = 1, HLD is set at the beginning 
of the command. Near the end of the command, after 
all the steps have been issued, an internal 15 ms 
delay occurs and the FD179X then waits for HLT to 
occur. 

For Type II and III commands with E flag off, HLD is 
made active and HLT is sampled until true. With E 
flag on, HLD is made active, an internal 15 ms delay 
occurs and then HLT is sampled until true. 

DISK READ OPERATIONS 

Sector lengths of 128, 256, 512 or 1024 are o btaina- 
ble in either FM or MFM formats. For FM, DDEN 
should be placed to logical "1." For MFM formats, 
DDEN should be placed to a logical "0." Sector 
lengths are determined at format time by a special 
byte in the "ID" field. If this Sector length byte in the 
ID field is zero, then the sector length is 128 bytes. If 
01 then 256 bytes. If 02, then 512 bytes. If 03, then 
the sector length is 1024 bytes. The number of sec- 
tors per track as far as the FD179X is concerned can 
be from 1 to 255 sectors. The number of tracks as far 
as the FD179X is concerned is from to 255 tracks. 
For IBM 3740 compatibility, sector lengths are 128 
bytes with 26 sectors per track. For System 34 com- 
patibility (MFM), sector lengths are 256 bytes/sector 
with 26 sectors/track; or lengths of 1024 bytes/sector 
with 8 sectors/track. (See Sector Length Table.) 

For re ad operations, the FD179X requires RAW 
READ Data (Pin 27) signal which is a 250 ns pulse 
per flux transition and a Read clock (RCLK) signal to 
indicate flux transition spacings. The RCLK (Pin 26) 
signal is provided by some drives but if not it may be 



derived externally by Phase lock loops, one shots, or 
counter techniques. In addition, a Read Gate Signal 
is provided as an output (Pin 25) which can be used 
to inform phase lock loops when to acquire syn- 
chronization. When reading from the media in FM. RG 
is made true when 2 bytes of zeroes are detected. 
The FD179X must find an address mark within the 
next 10 bytes; otherwise RG is reset and the search 
for 2 bytes of zeroes begins all over again. If an ad- 
dress mark is found within 10 bytes, RG remains true 
as long as the FD179X is deriving any useful informa- 
tion from the data stream. Similarly for MFM, RG is 
made active when 4 bytes of "00" or "FF" are de- 
tected. The FD179X must find an address mark 
within the next 16 bytes, otherwise RG is reset and 
search resumes. 

During read operations (WG = 0), the VFOE (Pin 33) 
is pro vided for phase lock loop synchronization. 
VFOE will go active when: 

a) Both HLT and HLD are True 

b) Settling Time, if programmed, has expired 

c) T he 179 X is inspecting data off the disk 

If WT/VFOE is not used, leave open or tie to a 1 0K 
resistor to +5. 

DISK WRITE OPERATION 

When writing is to take place on the diskette the 
Write Gate (WG) output is activated, allowing current 
to flow into the Read/Write head. As a precaution to 
erroneous writing the first data byte must be loaded 
into the Data Register in response to a Data Request 
from the FD179X before the Write Gate signal can be 
activated. 

Writing is inhibited when the Write Protect input is a 
logic low, in which case any Write command is im- 
mediately terminated, an interrupt is generated and 
the Write Protect status bit is set. The Write Fault in- 
put, when activated, signifies a writing fault condition 
detected in disk drive electronics such as failure to 
detect write current flow when the Write Gate is acti- 
vated. On detection of this fault the FD179X termi- 
nates the current command, and set s the Write Fault 
bit (bit 5) in the Status Word. The Write Fault input 
should be made inactive when the Write Gate output 
becomes inactive. 

For write operations, the FD179X provides Write 
Gate (Pin 30) and Write Data (Pin 31) outputs. Write 
data co nsists of a series of 500 ns pu lses in FM 
(DDEN = 1) and 250 ns pulses in MFM (DDEN = 0). 
Write Data provides the unique address marks in 
both formats. 

Also during write, two additional signals are provided 
for write precompensation. These are EARLY (Pin 
17) and LATE (Pin 18). EARLY is active true when 
the WD pulse appearing on (Pin 30) is to be written 
early. LATE is active true when the WD pulse is to be 
written LATE. If both EARLY and LATE are low when 
the WD pulse is present, the WD pulse is to be written at 
nominal. Since write precompensation values vary from 
disk manufacturer to disk manufacturer, the actual 
value is determined by several one shots or delay lines 
which are located external to the FD179X. The write 
precompensation signals EARLY and LATE are valid 
for the duration of WD in both FM and MFM formats. 
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Whenever a Read or Write command (Type II or III) 
is received the FD179X samples the Ready input. If 
this input is logic low the command is not executed 
and an interrupt is generated. All Type I commands 
are performed regardless of the state of the Ready 
input. Also, whenever a Type !l or III command is re- 
ceived, the TG43 signal output is updated. 

COMMAND DESCRIPTION 

The FD179X will accept eleven commands. Com- 
mand words should only be loaded in the Command 
Register when the Busy status bit is off (Status bit 0). 
The one exception is the Force Interrrupt command. 
Whenever a command is being executed, the Busy 
status bit is set. When a command is completed, an 
interrupt is generated and the Busy status bit is re- 
set. The Status Register indicates whether the com- 
pleted command encountered an error or was fault 
free. For ease of discussion, commands are divided 
into four types. Commands and types are sum- 
marized in Table 2. 



Table 2 COMMAND SUMMARY 



Table 4 FLAG SUMMARY 



BITS 


TYPE COMMAND 


7 


6 


5 


4 


3 


2 1 







Restore 














h 


V r, 


r 




Seek 











1 


h 


V r, 


r<> 




Step 








1 


u 


h 


V r, 


To 




Step In 





1 





u 


h 


V r, 


r<> 




Step Out 





1 


1 


u 


h 


V r, 


To 


II 


Read Sector 










m 


F 2 


E F, 





II 


Write Sector 







1 


m 


F, 


EF, 


a 


III 


Read Address 




1 











E 





III 


Read Track 




1 


1 








E 





III 


Write Track 




1 


1 


1 





E 





IV 


Force Interrrupt 




1 





1 


l 5 


I: I, 


lo 



TYPE II & III COMMANDS 



m = Multiple Record flag (Bit 4) 

m = 0, Single Record 
m = 1, Multiple Records 

ao = Data Address Mark (Bit 0) 

ao = 0, FB (Data Mark) 

ao = 1, F8 (Deleted Data Mark) 

E = 15 ms Delay (2MHz) 

E = 1, 15 ms delay 

E = 0, no 15 ms delay 

(F 2 ) S = Side Select Flag (179 1/3 only) 

S = 0, Compare for Side 
S = 1>Compare for Side 1 

(Fi) C = Side Compare Flag (1791/3 o nly) 
C = 0, disable side select compare 
C = 1, enable side select compare 

(F,) S = Side Select Flag 
(Bit 1, 1795/7 only) 
S = Update SSO to 
S = 1 Update SSO to 1 

(F ; ) b = Sector Length Flag 
(Bit 3, 1975/7 only) 





Sector Length Field 






00 01 10 


11 


b = 


256 


512 


1024 


128 


b = 1 


128 


256 


512 


1024 



Note: Bits shown in TRUE form. 



Table 3 FLAG SUMMARY 



Table 5 FLAG SUMMARY 



TYPE I COMMANDS 



h = Head Load Flag (Bit 3) 
h = 1, Load head at beginning 
h = 0, Unload head at beginning 

V = Verify flag (Bit 2) 

V = 1, Verify on destination track 

V = 0, No verify 

nrp = Stepping motor rate (Bits 1-0) 

Refer to Table 1 for rate summary 

u = Update flag (Bit 4) 

u = 1, Update Track register 
u = 0, No update 



TYPE IV COMMAND 



li = Interrupt Condition flags (Bits 3-0) 

10 = 1, Not-Ready to Ready Transition 

11 = 1, Ready to Not-Ready Transition 

12 = 1, Index Pulse 

13 = 1, Immediate Interrupt 

I3 -lg = 0, Terminate with no Interrupt 



TYPE I COMMANDS 

The Type I Commands include the Restore, Seek, 
Step, Step-in. and Step-Out commands. Each of the 
Type I Commands contains a rate field (ron), which 
determines the stepping motor rate as defined in 
Table 1. 
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The Type I Commands contain a head load flag (h) 
which determines if the head is to be loaded at the 
beginning of the command. If h = 1, the head is 
loaded at the beginning of the command (HLD output 
is made active). If h = 0, HLD is deactivated. Once 
the head is loaded, the head will remain engaged 
until the FD179X receives a command that specifi- 
cally disengages the head. If the FD179X is idle 
(busy = 0) for 15 revolutions of the disk, the head will 
be automatically disengaged (HLD made inactive). 

The Type I Commands also contain a verification (V) 
flag which determines if a verification operation is to 
take place on the destination track. If V = 1, a verifi- 
cation is performed, if V = 0, no verification is per- 
formed. 

During verification, the head is loaded and after an 
internal 15 ms delay, the HLT input is sampled. 
When HLT is active (logic true), the first encountered 
ID field is read off the disk. The track address of the 



ID field is then compared to the Track Register; if 
there is a match and a valid ID CRC, the verification 
is complete, an interrupt is generated and the Busy 
status bit is reset. If there is not a match but there is 
valid ID CRC, an interrupt is generated, and Seek 
Error Status bit (Status bit 4) is set and the Busy 
status bit is reset. If there is a match but not a valid 
CRC, the CRC error status bit is set (Status bit 3), 
and the next encountered ID field is read from the 
disk for the verification operation. If an ID field with a 
valid CRC cannot be found after four revolutions of 
the disk, the FD179X terminates the operation and 
sends an interrupt, (INTRQ). 

The Step, Step-in, and Step-Out commands contain 
an Update flag (U). When U = 1, the track register is 
updated by one for each step. When U = 0, the track 
register is not updated. 

On the 1795/7 devices, the SSO output is not affected 
during Type 1 commands, and an internal side com- 
pare does not take place when the (V) Verify Flag is 
on. 



QEJ 




V 6 



^ 




BESET DIRECTION 



^ 




SET DIRECTION 




TO HI RO FIELD 
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RESTORE (SEEK TRACK 0) 

Upon receipt of thi s comm and the Track 00 (TROO) 
input is sampled. If TROO is active low indicating the 
Read-Write head is positioned over track 0, the Track 
Register is l oaded with zeroes and an interrupt is 
generated. If TROO is not active low, stepping pulses 
(pins 15 to 16) at a ra te specified by the nro field are 
issued until the TROO input is activated. At this time the 
Track Register is l oaded with zeroes and an interrupt is 
generated. If the TROO input does not go active low 
after 255 stepping pulses, the FD179X terminates op- 
eration, interrupts, and sets the Seek error status bit. 
A verification operation takes place if the V flag is 
set. The h bit allows the head to be loaded at the 
start of command. Note that the Restore command is 
executed when MR goes from an active to an inac- 
tive state. 




BO BESET BUSY 



*0 RESET BusA 
T SEEK ERROR J 



(INTRO 1 

RESET BUSY J •* 



SEEK 

This command assumes that the Track Register con- 
tains the track number of the current position of the 
Read-Write head and the Data Register contains the 
desired track number. The FD179X will update the 
Track register and issue stepping pulses in the ap- 
propriate direction until the contents of the Track re- 
gister are equal to the contents of the Data Register 
(the desired track location). A verification operation 
takes place if the V flag is on. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the com- 
mand. 

STEP 

Upon receipt of this command, the FD179X issues 
one stepping pulse to the disk drive. The stepping 
motor direction is the same as in the previous step 
command. After a delay determined by thenro field, a 
verification takes place if the V flag is on. If the u flag is 
on, the Track Register is updated. The h bit allows the 
head to be loaded at the start of the command. An 
interrupt is generated at the completion of the command. 



STEP-IN 

Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 76. 
If the u flag is on, the Track Register is incremented 
by one. After a delay determined by the nrio field, a 
verification takes place if the V flag is on. The h bit 
allows the head to be loaded at the start of the 
command. An interrupt is generated at the comple- 
tion of the command. 

STEP-OUT 

Upon receipt of this command, the FD179X issues 
one stepping pulse in the direction towards track 0. If 
the u flag is on, the Track Register is decremented by 
one. After a delay determined by the nro field, a ver- 
ification takes place if the V flag is on. The h bit al- 
lows the head to be loaded at the start of the com- 
mand. An interrupt is generated at the completion of 
the command. 

TYPE II COMMANDS 

The Type II Commands are the Read Sector and 
Write Sector commands. Prior to loading the Type II 
Command into the Command Register, the computer 
must load the Sector Register with the desired sector 
number. Upon receipt of the Type II command, the 
busy status Bit is set. If the E flag = 1 (this is the 
normal case) HLD is made active and HLT is sam- 
pled after a 15 msec delay. If the E flag is 0, the 
head is loaded and HLT sampled with no 15 msec 
delay. The ID field and Data Field format are shown 
on page 13. 

When an ID field is located on the disk, the FD179X 
compares the Track Number on the ID field with the 
Track Register. If there is not a match, the next en- 
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countered ID field is read and a comparison is again 
made. If there was a match, the Sector Number of 
the ID field is compared with the Sector Register. If 
there is not a Sector match, the next encountered ID 
field is read off the disk and comparisons again 
made. If the ID field CRC is correct, the data field is 
then located and will be either written into, or read 
from depending upon the command. The FD179X 
must find an ID field with a Track number, Sector 
number, side number, and CRC within four revolutions 
of the disk; otherwise, the Record not found status bit is 
set (Status bit 3) and the command is terminated with an 
interrupt. 



Sector Length Table 



Soctor Length 
Field (hex) 



Number of Bytos 
in Soctor (decimal) 



00 
01 
02 
03 



128 

256 

512 

1024 



RESET BUSY 




Each of the Type II Commands contains an (m) flag 
which determines if multiple records (sectors) are to 
be read or writton, depending upon the command. If 
m = 0, a single sector is read or written and an inter- 
rupt is generated at the completion of the command. 
If m = 1, multiple records are read or written with the 
sector register internally updated so that an address 
verification can occur on the next record. The 
FD179X will continue to read or write multiple records 
and update the sector register until the sector regis- 
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ter exceeds the number of sectors on the track or 
until the Force Interrupt command is loaded into the 
Command Register, which terminates the command 
and generates an interrupt. 

If the Sector Register exceeds the number of sectors 
on the track, the Record-Not-Found status bit will be 
set. 

The Type II commands also contain side select com- 
pare flags. When C = 0, no side comparison is made. 
When C = 1 , the LSB of the side number is read off the 
ID Field of the disk and compared with the contents of 
the (S) flag. If the S flag compares with the side number 
recorded in the ID field, the 179X continues with the 
ID search. If a comparison is not made within 5 index 
pulses, the interrupt line is made active and the Record- 
Not-Found status bit is set. 

The 1795/7 READ SECTOR and WRITE SECTOR com- 
mands include a 'b' flag. The 'b' flag, in conjunction with 
the sector length byte of the ID Field, allows different 
byte lengths to be implemented in each sector. For IBM 
compatability, the *b' flag should be set to a one. The 




INTRO RESET BUST 



's' flag allows direct control over the SSO Line (Pin 25) 
and is set or reset at the beginning of the command, 
dependent upon the value of this flag. 

READ SECTOR 

Upon receipt of the Read Sector command, the head 
is loaded, the Busy status bit set, and when an ID 
field is encountered that has the correct track 
number, correct sector number, correct side number, 
and correct CRC, the data field is presented to the 
computer. The Data Address Mark of the data field must 
be found within 30 bytes in single density and 43 bytes in 
double density of the last ID field CRC byte; if not, the 
Record Not Found status bit is set and the operation is 
terminated. 

When the first character or byte of the data field has 
been shifted through the DSR, it is transferred to the 
DR, and DRQ is generated. When the next byte is 
accumulated in the DSR, it is transferred to the DR 
and another DRQ is generated. If the Computer has 
not read the previous contents of the DR before a 
new character is transferred that character is lost and 



(INTRO RESET BUSv\ 
SET LOST 0«'» 7 
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the Lost Data Status bit is set. This sequence con- 
tinues until the complete data field has been inputted 
to the computer. If there is a CRC error at the end of 
the data field, the CRC error status bit is set, and the 
command is terminated (even if it is a multiple record 
command). 

At the end of the Read operation, the type of Data 
Address Mark encountered in the data field is re- 
corded in the Status Register (Bit 5) as shown below: 

STATUS 
BIT 5 



1 


WRITE SECTOR 



Deleted Data Mark 
Data Mark 



Upon receipt of the Write Sector command, the head 
is loaded (HLD active) and the Busy status bit is set. 
When an ID field is encountered that has the correct 
track number, correct sector number, correct side num- 
ber, and correct CRC, a DRQ is generated. Vv. r-DY7" { 
counts off 1 1 bytes in single density and 22 bytes in 
double density from the CRC field and the Write Gate 
(WG) output is made active if the DRQ is serviced (i.e., 
the DR has been loaded by the computer). If DRQ has 
not been serviced, the command is terminated and the 
Lost Data status bit is set. If the DRQ has been ser- 
viced, the WG is made active and six bytes of zeros 
in single density and 12 bytes in double density are 
then written on tne disk. At tnis time the Data Ad- 
dress Mark is then written on the disk as determined 
by the ao field of the command as shown below: 

ao Data Address Mark (Bit 0) 



Deleted Data Mark 
Data Mark 



The FD179X then writes the data field and generates 
DRQ's to the computer. If the DRQ is not serviced in 
time for continuous writing the Lost Data Status Bit is 
set and a byte of zeros is written on the disk. The 
command is not terminated. After the last data byte 
has been written on the disk, tho two-byte CRC is 
computed internally and written on the disk followed 
by one byte of logic ones in FM or in MFM. The WG 
output is then deactivated. 

TYPE 111 COMMANDS 

READ ADDRESS 

Upon receipt of the Read Address command, the 
head is loaded and the Busy Status Bit is set. The 



next encountered ID field is then read in from the 
disk, and the six data bytes of the ID field are as- 
sembled and transferred to the DR, and a DRQ is 
generated for each byte. The six bytes of the ID field 
are shown below: 



TRACK 
ADDR 


SIDE 
NUMBER 


SECTOR 
ADDRESS 


SECTOR 
LENGTH 


CRC 
1 


CRC 
2 


1 


2 


3 


4 


5 


6 



Although the CRC characters are transferred to the 
computer, the FD179X checks for validity and the 
CRC error status bit is set if there is a CRC error. 
The Track Address of the ID field is written into the 
sector register. At the end of the operation an inter- 
rupt is generated and the Busy Status is reset. 

READ TRACK 

Upon receipt of the Read Track command, the head 
is loaded and the Busy Status bit is set. Reading 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse. 
As each byte is assembled it is transferred to the 
Data Register and the Data Request is generated for 
each byte. No CRC checking is performed. Gaps are 
included in the input data stream. The accumulation 
of bytes is synchronized to each Address Mark en- 
countered. Upon completion of the command, the in- 
terrupt is activated. RG is not activated during the 
Read Track Command. An internal side compare is not 
performed during a Read Track. 

WRITE TRACK 

Upon receipt of the Write Track command, the head 
is loaded and the Busy Status bit is set. Writing 
starts with the leading edge of the first encountered 
index pulse and continues until the next index pulse, 
at which time the interrupt is activated. The Data Re- 
quest is activated immediately upon receiving the 
command, but writing will not start until after the first 
byte has been loaded into the Data Register. If the 
DR has not been loaded by the time the index pulse 
is encountered the operation is terminated making 
the device Not Busy, the Lost Data Status Bit is set, 
and the Interrupt is activated, if a byte is not present 
in the DR when needed, a byte of zeros is substi- 
tuted. Address Marks and CRC characters are writ- 
ten on the disk by detecting certain data byte pat- 
terns in the outgoing data stream as shown in the 
table below. The CRC generator is initialized when 
any data byte from F8 to FE is about to be transfer- 
red from the DR to the DSR in FM or by receipt of 
F5 in MFM. 



GAP 
III 


ID 
AM 


TRACK 
NUMBER 


SIDE 
NUMBER 


SECTOR 
NUMBER 


SECTOR 
LENGTH 


CRC 
1 


CRC 
2 


GAP 
II 


DATA 
AM 


DATA FIELD 


CRC 
1 


CRC 
2 


ID FIELD 


DATA FIELD 



In MFM only, IDAM and DATA AM are preceded by three bytes of A1 with clock transition between bits 4 and 5 
missing. 
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(£V£ 






COPY S FLAG TO 
SSOLINE M795 7 0NIY.I 




♦ 




1 SET Hi 1 


NO 


XTX 






\< 




NO 


yT ISMS ^*V 






y^ ,s X S. 



(INTBQ A 

RESET BuSV J 





y^ DOES ^s. 

^ OSR ft 7> 


YES 

vES_ 
YES 


WRITE 2 CRC 
CHARS ClK FF 






J no 




^r DOCS \s_ 

^ osr fc y 


WRITE FC 
CLK 07 




Jno 




y< DOES X. 
£ osr FO FE ^. 
\ ORF8FB yf 


WRITE FO FE OR 
F8-F8 CLK C7 
INITIALIZE CRC 








WRITE DSR 



SET DATA LOST 




TYPE III COMMAND WRITE TRACK 



TYPE III COMMAND WRITE TRACK 

CONTROL BYTES FOR INITIALIZATION 



DATA PATTERN 
IN DR (HEX) 


FD179X INTERPRETATION 


FD1791/3 INTERPRETATION 
IN MFM (ODER = 0) 


IN FM (DDEN = 1) 


00 thru F4 


Write 00 thru F4 with CLK = FF 


Write 00 thru F4, in MFM 


F5 


Not Allowed 


Write A1* in MFM, Preset CRC 


F6 


Not Allowed 


Write C2** in MFM 


F7 


Generate 2 CRC bytes 


Generate 2 CRC bytes 


F8 thru FB 


Write F8 thru FB. Clk = C7, Preset CRC 


Write F8 thru FB, in MFM 


FC 


Write FC with Clk = D7 


Write FC in MFM 


FD 


Write FD with Clk = FF 


Write FD in MFM 


FE 


Write FE, Clk = C7, Preset CRC 


Write FE in MFM 


FF 


Write FF with Clk = FF 


Write FF in MFM 



•Missing clock transition between bits 4 and 5 



** Missing clock transition between bits 3 & 4 
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f ENTER ) 



SET BUSY 

RESET STATUS 

bits Z. 4. 5 



COPY S FLAG 
TO SSO LINE 
(1795/7 ONLY) 






3 









J SET INTRO A 

""l RESET BUSY I 



•II TEST- ♦. NO DELAY 
If TEST- 1 and CLK- 1 MHZ. 30 MS DELAY 



TYPE III COMMAND 

Read Track/Address 
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RESET BUSY 
SET INTRO 
SETRNF 



J 




TRANSFER TRACK 

NUMBER TO SECTOR 

REGISTOR 




c 



J 



TYPE III COMMAND 

Read Track/Address 



TYPE IV COMMAND 



FORCE INTERRUPT 

This command can be loaded into the command re- 
gister at any time. If there is a current command 
under execution (Busy Status Bit set), the command 
will be terminated and an interrupt will be generated 
when the condition specified in the lo through b field 
is detected. The interrupt conditions are shown be- 
low: 

lo = Not-Ready-To-Ready Transition 

li = Ready-To-Not-Ready Transition 

b = Every Index Pulse 

I3 = Immediate Interrupt (requires reset, see 
Note) 
NOTE: If lo - b = 0, there is no interrupt generated but 
the current command is terminated and busy is 
reset. This is the only command that will enable 
the immediate interrupt to clear on a subse- 
quent Load Command Register or Read Status 
liegister. 

STATUS DESCRIPTION 

Upon receipt of any command, except the Force In- 
terrupt command, the Busy Status bit is set and the 
rest of the status bits are updated or cleared for the 
new command. If the Force Interrupt Command is 
received when there is a current command under 
execution, the Busy status bit is reset, and the rest of 
the status bits are unchanged. If the Force Interrupt 
command is received when there is not a current 
command under execution, the Busy Status bit is 
reset and the rest of the status bits are updated or 
cleared. In this case, Status reflects the Type I com- 
mands. 



The format of the Status Register is shown below: 



(BITS) 


7 


6 


5 


4 I 3 


2 


1 





S7 


S6 


S5 


S4 | S3 


S2 


S1 


so 



Status varies according to the type of command exe- 
cuted as shown in Table 6. 
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FORMATTING THE DISK 

(Refer to section on Type III commands for flow diag- 
rams.) 

Formatting the disk is a relatively simple task when 
operating programmed I/O or when operating under 
Formatting the disk is accomplished by positioning 
the R/W head over the desired track number and is- 
suing the Write Track command. Upon receipt of the 
Write Track command, the FD179X raises the Data 
Request signal. At this point in time, the user loads 
the data register with desired data to be written on 
the disk. For every byte of information to be written 
on the disk, a data request is generated. This sequ- 
ence continues from one index mark to the next 
index mark. Normally, whatever data pattern appears 
in the data register is written on the disk with a nor- 
mal clock pattern. However, if the FD179X detects a 
data pattern of F5 thru FE in the data register, this is 
interpreted as data address marks with missing 
clocks or CRC generation. For instance, in FM an FE 
pattern will be interpreted as an ID address mark 
(DATA-FE, CLK-C7) and the CRC will be initialized. 
An F7 pattern will generate two CRC characters in 
FM or MFM. As a consequence, the patterns F5 thru 
FE must not appear in the gaps, data fields, or ID 
fields. Also, CRC's must be generated by an F7 pat- 
tern. 

Disks may be formatted in IBM 3740 or System 34 
formats with sector lengths of 128, 256, 512, or 1024 
bytes. 



IBM 3740 FORMAT— 128 BYTES/SECTOR 

Shown below is the IBM single-density format with 
128 bytes/sector. In order to format a diskette, the 
user must issue the Write Track command, and loac 1 
the data register with the following values. For ever) 
byte to be written, there is one data request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


40 


FF (orOO) 1 


6 


00 


1< 


FC (Index Mark) 


26 


FF (or 00) 


6 


00 


1 


FE (ID Address Mark) 


1 


Track Number 


1 


Side Number (00 or 01) 


1 


Sector Number (1 thru 1A) 


1 


00 


1 


F7 (2 CRC's written) 


11 


FF (or 00) 


6 


00 


r 


FB (Data Address Mark) 


128 


Data (IBM uses E5) 


1 


F7 (2 CRC's written) 


27 


FF (or 00) 


247" 


FF (or 00) 



•Write bracketed field 26 times 

"Continue writing until FD179X interrupts out. 

Approx. 247 bytes. 
1 -Optional '00' on 1795/7 only. 
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•■ r 
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IBM SYSTEM 34 FORMAT- 
256 BYTES/SECTOR 

Shown below is the IBM dual-density format with 256 
bytes/sector. In order to format a diskette the user 
must issue the Write Track command and load the 
data register with the following values. For every byte 
to be written, there is one data request. 



NUMBER 


HEX VALUE OF 


OF BYTES 


BYTE WRITTEN 


80 


4E 


12 


00 


3 


F6 




1 

50* 

12 


FC (Index Mark) 

4E 

00 




3 


F5 




1 
1 
1 
% 
1 


FE (ID Address Mark) 
Track Number (0 thru 4C) 
Side Number (0 or 1) 
Sector Number (1 thru 1A) 
01 




t 
22 


F7 (2 CRCs written) 
4E 




12 


00 




3 


F5 




1 

256 


FB (Data Address Mark) 
DATA 




1 
54 


F7 (2 CRCs written) 
4E 


598" 


4E 


* Write bracketed field 26 times 


* 'Continue writing until FD179X interrupts out. 
Approx. 598 bytes. 



1. NON-IBM FORMATS 

Variations in the IBM format are possible to a limited 
extent if the following requirements are met: sector 
size must be a choice of 128, 256, 512, or 1024 bytes; 
gap size must be according to the following table. Note 
that the Index Mark is not required by the 179X. The 
minimum gap sizes shown are that which is required by 
the 179X, with PLL lock-up time, motor speed variation, 
etc., adding additional bytes. 





FM 


MFM 


Gap I 


16 bytes FF 


32 bytes 4E 


Gap II 


11 bytes FF 


22 bytes 4E 


* 


6 bytes 00 


12 bytes 00 
3 bytes A1 


Gap III 


10 bytes FF 


24 bytes 4E 
3 bytes A1 


** 


4 bytes 00 


8 bytes 00 


Gap IV 


16 bytes FF 


16 bytes 4E 



•Byte counts must be exact. 
"*Byte counts are minimum, except exactly 3 bytes 
of A1 must be written. 



ELECTRICAL CHARACTERISTICS 
MAXIMUM RATINGS 

Vdd With Respect to Vss (Ground) =15 to -0.3V 
Max. Voltage to Any Input With =15 to -0.3V 
Respect to Vss 

Vdd = '^ ma Nominal ^CC = 35 ma Nominal 
OPERATING CHARACTERISTICS (DC) 
TA = 0°C to 70°C, Vdo = + 12V ± .6V, Vss = OV. Vcc = + 5V ± .25V 



Operating Temperature 
Storage Temperature 



0°C to 70°C 
-55°Cto+125°C 



SYMBOL 


CHARACTERISTIC 


MIN. 


MAX. 


UNITS 


CONDITIONS 


k 


Input Leakage 




10 


MA 


Vin = Voo 


lOL 


Output Leakage 




10 


ma 


Vout = Voo 


V.H 


Input High Voltage 


2 6 




V 




VlL 


Input Low Voltage 




0.8 


V 




VOH 


Output High Voltage 


2.8 




V 


lo = -100/:tA 


Vol 


Output Low Voltage 




0.45 


V 


lo = 1.6 mA 


Pd 


Power Dissipation 




0.5 


W 
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TIMING CHARACTERISTICS 

Ta = 0°C to 70°C, Vdo = + 12V ± .6V, Vss = OV, Vcc =+5V ± .25V 

READ ENABLE TIMING 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR & CS to RE 


50 






nsec 




THLD 


Hold ADDR & CS from RE 


10 






nsec 




TRE 


RE Pulse Width 


400 






nsec 


Cl = 50 pf 


TDRR 


DRQ Reset from RE 




400 


500 


nsec 




TIRR 


1NTRQ Reset from RE 




500 


3000 


nsec 


See Note 5 


TDACC 


Data Access from RE 






350 


nsec 


Cl = 50 pf 


TDOH 


Data Hold From RE 


50 




150 


nsec 


Cl = 50 pf 











' 


|Hw 




1 






1 


0,0 


«. T |M ^ 




—wJ 'service 




1 








f MtO 




o 




— '« — 


n 
















'SIT 


T D*CC [-•- 





1 "" 1 




| ..... | 






NOT 


> £5 

SERVI' 


MAY 61 WIMANfNT 
•C OOUfc.CS MfHEM C 

E (WORST CASE) 

SuS 

JSoS 


r Do4-*- 

TTICDLOWI'OCSMCO 
LOCK tMHi 



READ ENABLE TIMING 
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WRITE ENABLE TIMING 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TSET 


Setup ADDR & CS to WE 


50 






nsec 




THLD 


Hold ADDR & CS from Wl 


10 






nsec 




TWE 


WE Pulse Width 


350 






nsec 




TDRR 


DRQ Reset from WE 




400 


500 


nsec 




TIRR 


INTRQ Reset from WE 




500 


3000 


nsec 


See Note 5 


TDS 


Data Setup to WE 


250 






nsec 




TDH 


Data Hold from WE 


70 






nsec 





INPUT DATA TIMING: 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Tpw 

tbc 

Tc 

Txi 

TX2 


Raw Read Pulse Width 


100 

40 
40 


200 
1500 
1500 




nsec 
nsec 
nsec 
nsec 
nsec 


See Note 1 
1800 ns @ 70°C 
1800 ns@70°C 
See Note 1 


Raw Read Cycle Time 
RCLK Cycle Time 


RCLK hold to Raw Read 


Raw Read hold to RCLK 



_r 



H h 



k 



L 



- k 



=tt- 



NOTE 1 CS MAY BE PCRUANENTLV TIED LOW IF DESIRED 

2 WHEN WRITING DATA INTO SECTOR TRACK OR DATA 
REGISTER USER CANNOT READ THIS REGISTER UNTIL 
AT LEAST 4 M SEC IN UFM AFTER THE RISING EDGE OF WE 
, WHEN WRITING INTO THE COMMAND REGISTER STATUS 

IS NOT VALID UNTIL SOME 28 »SEC M FM, M uSEC IN MFM 
LATER THESE TIMES ARE DOUBLED WHEN CLK < 1 MHz 

'TIME DOUBLES WHEN CLOCK < IMHi 
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J 
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It m- 




h 


"i 


1 

H 






NOMINAL 


DISKETTE 


MODE 


DDEN 


CLK 


T. 


T k 


T, 


8" 


MFM 





2 MHz 


1 M» 


1 flS 


2 >is 


8" 


FM 


1 


2 MHz 


2 ia 


2iii 


4»*s 


5" 


MFM 





1 MHz 


2/iS 


2/iS 


4 fii 


5" 


FM 


1 


1 MHz 


4 (is 


4 M s 


8 n% 



INPUT DATA TIMING 



WRITE ENABLE TIMING 
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WRITE DATA TIMING: (ALL TIMES DOUBLE WHEN CLK = 1 MHz) 



SYMBOL 


CHARACTERISTICS 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


Twp 


Write Data Pulse Width 


450 


500 


550 


nsec 


FM 






150 


200 


250 


nsec 


MFM 


Twg 


Write Gate to Write Data 




2 
1 




/xsec 
usee 


FM 
MFM 


Tbc 


Write data cycle Time 




2,3, or 4 




/xsec 


± CLK Error 


Ts 


Early (Late) to Write Data 


125 






nsec 


MFM 


Th 


Early (Late) From 
Write Data 


125 






nsec 


MFM 


Twf 


Write Gate off from WD 




2 
1 




tisec 
/isec 


FM 
MFM 


Twdl 


WD Valid to Clk 


100 
50 






nsec 
nsec 


CLK=1 MHZ 
CLK =2 MHZ 


Twd2 


WD Valid after CLK 


100 
30 






nsec 
nsec 


CLK=1 MHZ 
CLK =2 MHZ 



~L 



CLK 
(2MHZ) 



~L 



h 



l_ 



V/////A V////A 

Twdl M L Twd2 




V/////A V/////A 



WRITE DATA/CLOCK RELATIONSHIP 
(DDEN-0) 



WRITE DATA TIMING 
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MISCELLANEOUS TIMING: 



SYMBOL 


CHARACTERISTIC 


MIN. 


TYP. 


MAX. 


UNITS 


CONDITIONS 


TCD. 


Clock Duty (low) 


230 


250 


20000 


nsec 




TCD2 


Clock Duty (high) 


200 


250 


20000 


nsec 




TSTP 


Step Pulse Output 


2or4 






fisec 


See Note 5 


TDIR 


Dir Setup to Step 




12 




fisec 


±CLK ERROR 


TMR 


Master Reset Pulse Width 


50 






usee 




TIP 


Index Pulse Width 


10 






^sec 


See Note 5 


TWF 


Write Fault Pulse Width 


10 






^isec 



w. }- 



h- - -H 



K- - H 




_r^ 



I— HH — h-h- h'-H'-K 



-ih 



MISCELLANEOUS TIMING 



NOTES: 

1. Pulse width on RAW READ (Pin 27) is normally 
100-300 ns. However, pulse may be any width if 
pulse is entirely within window. If pulse occurs in both 
windows, then pulse width must be less than 300 ns 
for MFM at CLK = 2 MHz and 600 ns for FM at 2 
MHz. Times double for 1 MHz. 

2. A PPL Data Separator is recommended for 8" MFM. 



3. tbc should be 2 /xs, nominal in MFM and 4 its nominal 
in FM. Times double when CLK = 1 MHz. 

4. RCLK may be high or low during RAW READ (Polarity 
is unimportant). 

5. Times double when clock = 1 MHz. 
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FD179X Application Notes 



INTRODUCTION 



SYSTEM DESIGN 



Over the past several years, the Floppy Disk Drive has 
become the most popular on-line storage device for 
mini and microcomputer systems. Its fast access time, 
reliability and low cost-per-bit ratio enables the Floppy 
Disk Drive to be the solution in mass storage for mi- 
croprocessor systems. The drive interface to the Host 
system is standardized, allowing the OEM to substitute 
one drive for another with minimum hardware/ software 
modifications. '* 



Since Floppy Disk Data is stored and retrieved as a 
self-clocking serial data stream, some means of sep- 
arating the clock from the data and assembling this 
data in parallel form must be accomplished. Data is 
stored on individual Tracks of the media, requiring con- 
trol of a stepper motor to move the Read/Write head 
to a predetermined Track. Byte sychronization must 
also be accomplished to insure that the parallel data 
is properly assembled. After all the design considera- 
tions are met, the final controller can consist of 40 or 
more TTL packages. 

To alleviate the burden of Floppy Disk Controller de- 
sign, Western Digital has developed a Family of LSI 
Floppy Disk controller devices. Through its own set of 
macro commands, the FD179X Controller Family will 
perform all the functions necessary to read and write 
data to the drive. Both the 8" standard and 5V«" mini- 
floppy are supported with single or double density re- 
cording techniques. The FD179X is compatible with 
the IBM 3740 (FM) data format, or the System 34 
(MFM) standards. Provisions for non-standard formats 
and variable sector lengths have been included to pro- 
vide more storage capability per track. Requiring stan- 
dard +5, + 12 power supplies the FD179X is available 
in a standard 40 pin dual-in-line package. 

The FD179X Family consists of 6 devices. The 
differences between these devices is summarized in 
Figure 1. The 1792 and 1794 are "single density only" 
devices, with the Double Density Enable pin (DDEN) 
left open by the user. Both True and inverted Data bus 
devices are available. Since the~T79X can only drive 
one TTL Load, a true data bus system may use the 
1791 with external inverting buffers to arrive at a true 
bus scheme. Tfcie 4795 ana T797 are identical to the 
1791 and 1793, except a side select output has been 
added that is controlled through the Command Register. 



The first consideration in Floppy Disk Design is to de- § 
termine which type of drive to use. The choice ranges 
from single-density single sided mini-floppy to the 8" 
double-density double-sided drive. Figure 2 illustrates 
the various drive and data capacities associated with 
each type. Although the 8" double-density drive offers 
twice as much storage, a more complex data separator 
and the addition of Write Precompensation circuits are 
mandatory for reliable data transfers. Whether to go 
with 8" double-density or not is dependent upon PC 
board space and the additional circuitry needed to ac- 
curately recover data with extreme bit shifts. The byte 
transfer time defines the nominal time required to 
transfer one byte of data from the drive. If the CPU 
used cannot service a byte in this time, then a DMA 
scheme will probably be required. The 179X also needs 
a few microseconds for overhead, which is subtracted 
from the transfer time. Figure 3 shows the actual ser- 
vice times that the CPU must provide on a byte-by-byte 
basis. If these times are not met, bytes of data will be 
lost during a read or write operation. For each byte 
transferred, the 179X generates a DRQ (Data Re- 
quest) signal on Pin 38. A bit is provided in the status 
register which is also set upon receipt of a byte from 
the Disk. The user has the option of reading the status 
register through program control or using the DRQ Line 
with DMA or interrupt schemes. When the data register 
is read, both the status register DRQ bit and the DRQ 
Line are automatically reset. The next full byte will 
again set the DRQ and the process continues until the 
sector(s) are read. The Write operation works exactly- - 
the same way, except a WRITE to the Data Register 
causes a reset of both DRQ's. 



RECORDING FORMATS 

The FD179X accepts data from the disk in a Fre- 
quency-Modulated (FM) or Modified-Frequency-Mod- 
ulated (MFM) Format. Shown in Figures 4A and 4B are 
both these Formats when writing a Hexidecimal byte 
of 'D2'. In the FM mode, the 8 bits of data are broken 
' up into "bit cells." Each bit cell begins with a clock 
pulse and the center of the bit cell defines the data. If 
the data bit = 0, no pulse is written; if the data = 1, 
a pulse is written in the center of the cell. For the 8" 
drive, each clock is written 4 microseconds apart. 




n«miri',7 i i i i i win.iii i in i i«i 
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In the MFM mode, clocks are decoded into the data 
stream. The byte is again broken up into bit cells, with 
the data bit written in the center of the bit cell if data 
= 1. Clocks are only written if both surrounding data 
bits are zero. Figure 4B shows that this occurs only 
once between Bit cell 4 and 5. Using this encoding 
scheme, pulses can occur 2, 3 or 4 microseconds 
apart. The bit cell time is now 2 microseconds; twice 
as much data can be recorded without increasing the 
Frequency rate due to this encoding scheme. 

The 179X was designed to be compatible with the IBM 
3740 (FM) and System 34 (MFM) Formats. Although 
most users do not have a need for data exchange with 
IBM mainframes, taking advantage of these well stud- 
ied formats will insure a high degree of system 
performance. The 179X will allow a change in gap 
fields and sector lengths to increase usable storage 
capacity, but variations away from these standards is 
not recommended. Both IBM standards are soft-sector 
format. Because of the wide variation in address marks, 
the 179X can only support soft-sectored media. Hard 
sectored diskettes have continued to lose popularity, 
mainly due to the unavailability of a standard and the 
limitation of sector lengths imposed by the physical 
sector holes in the diskette. 



PROCESSOR INTERFACE 

The Interface of the 179X to the CPU consists of an 
8-bit Bi-directional bus, read/write controls and optional 
interrupt lines. By selecting the device via the CHIP 
SELECT Line, each of the five internal registers can 
be accessed. 



Shown below are the registers and their addresses: 



PIN 3 


PIN 6 


PIN 5 


PIN 4 


PIN 2 


CS 


A, 


A 


RE=^f 


WE=^f 











STATUS REG 


COMMAND 
REG 








1 


TRACK REG 


TRACK REG 





1 





SECTOR REG 


SECTOR REG 





1 


1 


DATA REG 


DATA REG 


1 


X 


X 


H1-Z 


H1-Z 



The Aq, A,, Lines used for register selections can be 
configured at the CPU in a variety of ways. These lines 
may actually tie to CPU address lines, in which case 
the 179X will be memory-mapped and addressed like 
RAM. They may also be used under Program Control 
by tying to a port device such as the 8255, 6820, etc. 
As a diagnostic tool when checking out the CPU in- 
terface, the Track and Sector registers should respond 
like "RAM" when the 179X is idle (Busy = INTRQ = 
0). 

Because of internal synchronization cycles, certain 
time delays must be introduced when operating under 
Programmed I/O. The worst case delays are: 



OPERATION 


NEXT 
OPERATION 


DELAY REQ'D 


WRITE TO 
COMMAND REG 


READ STATUS 
REGISTER 


MFM = 14/xs* 
FM = 28 M s. 


WRITE TO 
ANY REGISTER 


READ FROM A 
DIFFERENT REG 


NO DELAY 



•NOTE: Times Double when CLK = 1MHz (5V4" drive) 



Other CPU interface lines are CLK, MR and DDEN. 
The CLK line should be 2MHz (8" drive) or 1MHz (5V4" 
drive) with a 50% duty cycle. Accuracy should be ±1% 
(crystal source) since all internal timing, including step- 
ping rates, are based upon this clock. 

The MR or Master Reset Line should be strobed a 
minimum of 50 microseconds upon each power-on 
condition. This line clears and initializes all internal reg- 
isters and issues a restore command (Hex '03') on the 
rising edge. A quicker steppin g rat e can be written to 
the command register after a MR", in which case the 
remaining steps will occur at the faster programmed 
rate. The 179X will issue a maximu m of 25 5 stepping 
pulses in an attempt to expect the TROO line to go 
active l ow. This line should be connected to the drive's 
TROO sensor. 



The DDEN line causes selection of either singl e den- 
sity (DDEN = 1) or double density operation. DDEN 
should not be switched during a read or write operation. 



Each time a command is issued to the 1 79X, the Busy 
bit is set and the INTRQ (Interrupt Request) Line is 
reset. The user has the option of checking the busy bit 
or use the INTRQ Line to denote command comple- 
tion. The Busy bit will be reset whenever the 179X is 
idle and awaiting a new command. The INTRQ Line, 
once set, can only be reset by a READ of the status 
register or issuing a new command. The MR (Master 
Reset) Line does not affect INTRQ. 
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FLOPPY DISK INTERFACE 

The Floppy Disk Interface can be divided into three 
sections: Motor Control, Write Signals and Read Sig- 
nals. All of these lines are capable of driving one TTL 
load and not compatible for direct connection to the 
drive. Most drives require an open-collector TTL inter- 
face with high current drive capability. This must be 
done on all outputs from the 179X. Inputs to the 179X 
may be buffered or tied to the Drives outputs, providing 
the appropriate resistor termination networks are used. 
Undershoot should not exceed -0.3 volts, while integ- 
rity of V| H and V 0H levels should be kept within spec. 

MOTOR CONTROL 

Motor Control is accomplished by the STEP and DIRC 
Lines. The STEP Line issues stepping pulses with a 
period defined by the rate field in all Type I commands. 
The DIRC Line defines the direction of steps (DIRC = 
1 STEP IN/DIRC = STEP OUT). 
Other Control Lines include the IP or Index Pulse. This 
Line is tied to the drives' Index L.E.D. sensor and 
makes an ac tive tra nsition for each revolution of the 
diskette. The TROO Line is another L.E.D. sunsoi that 
informs the 179X that the stepper motor is at its fur- 
thest position, over Track 00. The READY Line can be 
used for a number of functions, such as sensing "door 
open", Drive motor on, etc. Most drives provide a pro- 
grammable READY Signal selected by option jumpers 
on the drive. The 1 79X will look at the ready signal prior 
to executing READ/WRITE commands. READY is nor 
inspected during any Type I commands. All Type I 
commands will execute regardless of the Logic Level 
on this Line. 

WRITE SIGNALS 

Writing of data is accomplished by the use of the WD, 
WG, WF, TG43, EARLY and LATE Lines. The WG or 
Write Gate Line is used to enable write current at the 
drive's R/W head. It is made active prior to writing data 
on the disk? The WF or WRITE FAULT Line is used to 
inform the 179X of a failure in drive electronics. This 
signal is multiplexed with the VFOE Line and must be 
logically separated if required. Figure 5 illustrates three 
methods of demultiplexing. 

The TG43 or "TrACK GREATER than 43" Line is 
used to decrease the Write current on the inner tracks, 
where bit densities are the highest. If not required on 
the drive, TG43 may be left open. 

WRITE PRECOMPENSATION 

The 179X provides three signals for double density 
Write Precompensation use. These signals are WRITE 
DATA, EARLY and LATE. When using single density 
drives (eighter 8" or 5 1 /»"), Write Precompensation is 
not necessary and the WRITE DATA line is generally 
TTL Buffered and sent directly to the drive. In this 
mode, EARLY and LATE are left open. 
For double density use, Write Precompensation is a 
function of the drive. Some manufacturers recommend 
Precompensating the 5W drive, while others do not. 
With the 8" drive, Precompensation may be specified 
from TRACK 43 on, or in most cases, all TRACKS. If 
the recommended Precompensation is not specified, 



check with the manufacturer for the proper configura- 
tion required. 

The amount of Precompensation time also varies. A 
typical value will usually be specified from 100-300ns. 
Regardless of the parameters used, Write Precom- 
pensat ion must be done external to the 179X. When 
DDEN is tied low, EARLY or LATE will be activated at 
least 125ns. before and after the Write Data pulse. An 
Algorithm internal the 179X decides whether to raise 
EARLY or LATE, depending upon the previous bit pat- 
tern sent. As an example, suppose the recommended 
Precomp value has been specified at 150ns. The fol- 
lowing action should be taken: 



EARLY LATE 



ACTION TAKEN 



delay WD by 150ns (nominal) 
1 delay WD by 300ns (2X value) 
1 do not delay WD 

There are two methods of performing Write 
Precompensation: 

1 ) External Delay elements 

2) Digitally 

Shown in Figure 6 is a Precomp circuit using the West- 
ern Digital 2143 clock generator as the delay element. 
The WD pulse from the 179X creates a strobe to the 
2143, causing subsequent output pulses on the-CTl ,.02 
and j03 signals. The 5K Precomp adjust sets the de- 
sired Precomp value. Depending upon the condition of 
EARLY and LATE, 0-\ will be used for EARLY, 02 for 
nominal (EARLY = LATE = 0), and J03 for LATE. The 
use of "one-shots" or delay line in a Write Precom- 
pensation scheme offers the user the ability to vary the 
Precomp value. The J04 output resets the 74LS175 
Latch in anticipation of the next WD pulse. Figure 7 
shows the WD-EARLY/LATE relationship, while Figure 
8 shows the timing of this write Precomp scheme. 
Another method of Precomp is to perform the function 
digitally. Figure 9 illustrates a relationship between the 
WD pulse and the CLK pin, allowing a digital Precomp 
scheme. Figure 10 shows such a scheme with a pre- 
set Write Precompensation value of 250ns. The syn- 
chronous counter is used to generate 2MHz and 4MHz 
clock signals. The 2MHz clock is sent to the CLK input 
of the 179X and the 4MHz is used by the 4-bit shift 
register. When a WD pulse is not present, the 4MHz 
clock is shifting "ones" through the shift register and 
maintaining Q at a zero level. When a WD pulse is 
present, a zero is loaded at either A, B, or C depending 
upon the states of LATE, EN PRECOMP and EARLY. 
The zero is then shifted by the 4MHz clock until it 
reaches the Q D output. The number of shift operations 
determines whether the WRITE DATA pulse is written 
early, nominal or late. If both FM and MFM operations 
is a system requirement, the output of this circuit should 
be disabled and the WD pulse should be sent directly 
to the drive. 
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DATA SEPARATION 

The 179X has two inputs (RAW READ & RCLK) and 
one output (VFOE) for use by an external data sepa- 
rator. The RAW READ input must present clock and 
data pulses to the 179X, while the RCLK input provides 
a "window" or strobe signal to clock each RAW READ 
pulse into the device. An ideal Data Separator would 
have the leading edge of the RAW READ pulse occur 
in the exact center of the RCLK strobe. 
Motor Speed Variation, Bit shifts and read amplifier 
recovery circuits all cause the RAW READ pulses to 
drift away from their nominal positions. As this occurs, 
the RAW READ pulses will shift left or right with re- 
spect to RCLK. Eventually, a pulse will make its tran- 
sition outside of its RCLK window, causing either a 
CRC error or a Record-not-Found error at the 179X. 
A Phase-Lock-Loop circuit is one method of achieving 
synchronization between the RCLK and RAW READ 
signals. As RAW READ pulses are fed to the PLL, 
minor adjustments of the free-running RCLK frequency 
can be made. If pulses are occurring too far apart, the 
RCLK frequency is decreased to keep synchroniza- 
tion. If pulses begin to occur closer together, RCLK is 
increased until this new higher frequency is achieved. 
In normal read operations, RCLK will be constantly 
adjusted in an attempt to match the incoming RAW 
READ frequency. 

Another method of Data Separation is the Counter- 
Separator technique. The RCLK signal is again free- 
running at a nominal rate, until a RAW READ pulse 
occurs. The Separator then denotes the position of the 
pulse with respect to RCLK (by the counter value), and 
counts down to increase or decrease the current RCLK 
window. The next RCLK window will occur at a nominal 
rate and will continue to run at this frequency until an- 
other RAW READ pulse adjusts RCLK, but only the 
present window is adjusted. 

Both PPL and Counter/Separator are acceptable 
methods of Data Separation. The PPL has the highest 
reliability because of its "tracking" capability and is rec- 
ommended for 8" double density designs. 
As a final note, the term "Data Separator" may be 
misleading, since the physical separation of clock and 
data bits are not actually performed. This term is used 
throughout the industry, and can better be described 
as a "Data Recovery Circuit" rather than a Data 
Separator. 

The VFOE signal is an output from the 179X that sig- 
nifies the head has been loaded and valid data pulses 
are appearing on the RAW READ line. It can be used 
to enable the Data Separator and to insure clean RCLK 
transitions to the 179X. Since some drives will output 
random pulses when the head is disengaged, VFOE 
can prevent an erratic RCLK signal during this time. If 
the Data Separator requires synchronization during a 
known pattern of one's or zero's, then RG (READ 
GATE) can be used. The RG signal will go active when 
the 1 79X is currently over a field of zeros or ones. RG 
is not available on the 1795/1797 devices, since this 
signal was replaced with the SSO (Side Select Output) 
Line. 



Shown in Figure 1 1 is a 2Vi IC Counter/Separator. The 
74LS193 free runs at a frequency determined by the 
CRYCLK input. When a RAW READ pulse occurs, the 
counter is loaded with a starting count of '5'. When the 
RAW READ Line returns to a Logic 1, the counter 
counts down to zero and again free runs. The 74LS74 
insures a 50% duty cycle to the 1 79X and performs a 
divide-by-two of the Q D output. 
Figure 12 illustrates another Counter/Separator utiliz- 
ing a PROM as the count generator. Depending upon 
the RAW READ phase relationship to RCLK, the PROM 
is addressed and its data output is used as the counter 
value. A 16MHz clock is required for 8" double density, 
while an 8MHz clock can be used for single density. 
Figure 13 shows a Phase-Lock-Loop data recovery 
circuit. The phase detector (U2, Figure 2) compares 
the phase of the SHAPED DATA pulse to the phase 
of VFO CLK - 2. If VFO CLK 4 2 is lagging the 
SHAPED DATA pulse an output pulse on #9, U2 is 
generated. The filter/amplifier converts this pulse into 
a DC signal which increases the frequency of the VCO. 
If, correspondingly, CLK + 2 is leading the SHAPED 
DATA pulse, an output pulse on #5, U2 is generated. 
This pulse is converted into a DC signal which de- 
creases the frequency of the VCO. These two actions 
cause the VCO to track the frequency of the incoming 
READ DATA pulses. This correction process to keep 
the two signals in phase is constantly occurring because 
of spindle speed variation and circuit parameter 
variations. 

The operating specifications for this circuit are as 
follows: 



Free Running Frequency 


2MHz 


Capture Range 


± 15% 


Lock Up Time 


50 microsec. "1111" or 




"0000" Pattern 




100 Microsec "1010" Pat- 




tern 



The RAW READ pulses are generated from the falling 
edge of the SHAPED DATA pulses. The pulses are 
also reshaped to meet the 179X requirements. VFO 
CLK + 2 OR 4 is divided by 2 once again to obtain 
VFO CLK OUT whose frequency is that required by the 
179X RCLK input. RCLK must be controlled by VFOE 
so VFOE is sampled on each rising edge of VFO CLK 
OUT. When VFOE goes active EN RCLK goes active 
in synchronization with VFO CLK OUT preventing any 
glitches on the RCLK output. When VFOE goes inac- 
tive EN RCLK goes inactive in synchronization with 
VFO CLK OUT, again preventing any glitches on the 
RCLK output. 

Figure 14 illustrates a PPL data recovery circuit using 
the Western Digital 1691 Floppy Support device. Both 
data recovery and Write Precomp Logic is contained 
within the 1691, allowing low chip count and PLL re- 
liability. The 74S124 supplies the free-running VCO 
output. The PUMP UP and PUMP DOWN signals from 
the 1691 are used to control the 74S124's frequency. 
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COMMAND USAGE 

Whenever a command is successfully or unsuccess- 
fully completed, the busy bit of the status register is 
reset and the INTRQ line is forced high. Command ter- 
mination may be detected either way. The INTRQ can 
be tied to the host processor's interrupt with an appro- 
priate service routine to terminate commands. The 
busy bit may be monitored with a user program and 
will achieve the same results through software. Per- 
forming both an INTRQ and a busy bit check is not 
recommended because a read of the status register to 
determine the condition of the busy bit will reset the 
INTRQ line. This can cause an INTRQ from not 
occurring. 

RESTORE COMMAND 

On some disk drives, it is possible to position the R/W 
head outward past Track 00 and prevent the TROO 
line from going low unless a STEP IN is first performed. 
If this condition exists in the drive used, the RESTORE 
command will never detect a TROO. Issuing several 
STEP IN pulses before a RESTORE command will 
remedy this situation. The RESTORE and all other 
Type I commands will execute even though the READY 
bit indicates the drive is not ready (NOT READY = 1). 

READ TRACK COMMAND 

The READ TRACK command can be used to manually 
inspect data on a hard copy printout. Gaps, address 
marks and all data are brought in to the data register 
during this command. The READ TRACK command 
may be used to inspect diskettes for valid formatting 
and data fields as well as address marks. Since the 
179X does not synchronize clock and data until the In- 
dex Address Mark is detected, data previous to this ID 
mark will not be valid. READ GATE (RG) is not ac- 
tuated during this command. 

READ ADDRESS COMMAND 

In systems that use either multiple drives or sides, the 
read address command can be used to tell the host 
processor which drive or side is selected. The current 
position of the R/W head is also denoted in the six 
bytes of data that are sent to the computer. 



TRACK SIDE 


SECTOR 


CRS 
LENGTH 


CRC 
1 


CRC 
2 



The READ ADDRESS command as. well as all other 
Type II and Type III commands will not execute if the 
READY line is inactive (READY = 0). Instead, an in- 
terrupt will be generated and the NOT READY status 
bit will be set to a 1. 



FORCED INTERRUPT COMMAND 

The Forced Interrupt command is generally used to 
terminate a multiple sector command or to insure Type 
I status in the status register. The lower four bits of the 
command determine the conditional interrupt as follows: 



1 = NOT-READY TO READY TRANSITION 

1, = READY TO NOT-READY TRANSITION 

1 2 = EVERY INDEX PULSE 

1 3 = IMMEDIATE INTERRUPT 



Regardless of the conditional interrupt set, any com- 
mand that is currently being executed when the Forced 
Interrupt command is loaded will immediately be ter- 
minated and the busy bit will be reset indicating an idle 
condition. 

Then, when the condition for interrupt is met, the INTRQ 
line will go high signifying that the condition specified 
has occurred. 

The conditional interrupt is enabled when the corre- 
sponding bit positions of the command (l 3 -l ) are set 
to a 1 . If l 3 - 1 are all set to zero, no interrupt will occur, 
but any command presently under execution will be 
immediately terminated upon receipt of the Force In- 
terrupt command (HEX DO). 
As usual, to clear the interrupt a read of the status reg- 
ister or a write to the command register is required. 
The exception is when using the immediate interrupt 
condition (l 3 = 1). If this command is loaded into the 
command register, an interrupt will be immediately 
generated and the current command terminated. 
Reading the status or writing to the command register 
will not automatically clear the interrupt; another forced 
interrupt command with l 3 -l = must be loaded into 
the command register in order to reset the INTRQ from 
this condition. 

More than one condition may be set at a time. If for 
example, the READY TO NOT-READY condition (I, = 
1) and the Every Index Pulse (l 2 = 1) are both set, the 
resultant command would be HEX "DA". The "OR" 
function is performed so that either a READY TO NOT- 
READY or the next Index Pulse will cause an interrupt 
condition. 

DATA RECOVERY 

Occasionally, the R/W head of the disk drive may get 
"off track", and dust or dirt may get trapped on the 
media. Both of these conditions will cause a RECORD 
NOT FOUND and/or a CRC error to occur. This "soft 
error" can usually be recovered by the following 
procedure: 

1 . Issue the command again 

2. Unload and load the head and repeat step 

3. Issue a restore, seek the track, and repeat step 1 




If RNF or CRC errors are still occurring after trying 
these methods, a "hard error" may exist. This is usu- 
ally caused by improper disk handling, exposure to 
high magnetic fields, etc. and generally results in de- 
stroying portions or tracks of the diskette. 



359 



FIGURE 1 DEVICE CHARACTERISTICS 



DEVICE 


SNGL DENSITY 


DBLE DENSITY 


INVERTED BUS 


TRUE BUS 


DOUBLE-SIDED 


1791 


X 


X 


X 






1792 


X 




X 






1793 


X 


X 




X 




1794 


X 






X 




1795 


X 


X 


X 




X 


1797 


X 


X 




X 


X 



FIGURE 2 STORAGE CAPACITIES 



SIZE 


DENSITY 


SIDES 


UNFORMATTED 
CAPACITY (NOMINAL) 


BYTE 

TRANSFER 

TIME 


FORMATTED 
CAPACITY 


PER TRACK 


PER DISK 


PER TRACK 


PER DISK 


5 1 A" 

5V4" 

5V4" 

5V4" 

8" 

8" 

8" 

8" 


SINGLE 

DOUBLE 

SINGLE 

DOUBLE 

SINGLE 

DOUBLE 

SINGLE 

DOUBLE 


1 
1 
2 
2 
1 
1 
2 
2 


3125 
6250 
3125 
6250 
5208 

10,416 
5208 

10,416 


109,375* 
218,750 
218,750 
437,500 
401,016 
802,032 
802,032 
1,604,064 


64/j.s 
32/iS 
64/ns 
32/iS 
32^s 
16/iS 
32ms 
16/lis 


2304" 

4608*** 

2304 

4608 

3328 

6656 

3328 

6656 


80,640 
161,280 
161,280 
322,560 
256,256 
512,512 
512,512 
1,025,024 



•Based on 35 Tracks/Side 

•Based on 18 Sectors/Track (128 byte/sec) 

*Based on 18 Sectors/Track (256 bytes/sec) 
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11.5 Appendex E - Z80A CPU 



Z8400 

Z80 CPU Central 

Processing Unit 




Zilog 



Product 
Specification 



March 1981 



Features □ The instruction set contains 158 instructions. 

The 78 instructions of the 8080A are 
included as a subset; 8080A software com- 
patibility is maintained. 

□ Six MHz, 4 MHz and 2.5 MHz clocks for the 
Z80B, Z80A, and Z80 CPU result in rapid 
instruction execution with consequent high 
data throughput. 

□ The extensive instruction set includes string, 
bit, byte, and word operations. Block 
searches and block transfers together with 
indexed and relative addressing result in 
the most powerful data handling capabilities 
in the microcomputer industry. 

□ The Z80 microprocessors and associated 
family of peripheral controllers are linked 
by a vectored interrupt system. This system 



may be daisy-chained to allow implemen- 
tation of a priority interrupt scheme. Little, 
if any, additional logic is required for 
daisy-chaining. 

Duplicate sets of both general-purpose 
and flag registers are provided, easing 
the design and operation of system soft- 
ware through single-context switching, 
background-foreground programming, and 
single-level interrupt processing. In addi- 
tion, two 16-bit index registers facilitate 
program processing of tables and arrays. 

There are three modes of high speed inter- 
rupt processing: 8080 compatible, non-Z80 
peripheral device, and Z80 Family 
peripheral with or without daisy chain. 

On-chip dynamic memory refresh counter. 
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CONTROL 
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Ai 
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QND D ( 

Dr 









































































































DATA 
BUS 




Figure 1. Pin Functions 



Figure 2. Pin Assignments 
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General The Z80, Z80A, and Z80B CPUs are third- 

Description generation single-chip microprocessors with 
exceptional computational power. They offer 
higher system throughput and more efficient 
memory utilization than comparable second- 
and third-generation microprocessors. The 
internal registers contain 208 bits of read/write 
memory that are accessible to the programmer. 
These registers include two sets of six general- 
purpose registers which may be used 
individually as either 8-bit registers or as 
16-bit register pairs. In addition, there are two 
sets of accumulator and flag registers. A group 
of "Exchange" instructions makes either set of 
main or alternate registers accessible to the 
programmer. The alternate set allows operation 
in foreground-background mode or it may 



be reserved for very fast interrupt response. 
The Z80 also contains a Stack Pointer, Pro- 
gram Counter, two index registers, a Refresh 
register (counter), and an Interrupt register. 
The CPU is easy to incorporate into a system 
since it requires only a single + 5 V power 
source, all output signals are fully decoded 
and timed to control standard memory or 
peripheral circuits, and is supported by an 
extensive family of peripheral controllers. The 
internal block diagram (Figure 3) shows the 
primary functions of the Z80 processors. 
Subsequent text provides more detail on the 
Z80 I/O controller family, registers, instruction 
set, interrupts and daisy chaining, and CPU 
timing. 



■<Jr 



CPU 
TIMING 
CONTROL 



8-bit 

DATA BUS 



/ INST. / 

\ "ED. *y 



INTERNAL DATA BUS 



\ CPU 

J TIMING 



OTT 

8 SYSTEMS 5 CPU 

AND CPU CONTROL 
CONTROL INPUTS 
OUTPUTS 



} 



^> 






ADDRESS 
LOGIC AND 
BUFFERS 



a 



16-BIT 
ADDRESS BUS 



Figure 3. Z80 CPU Block Diagram 
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Z80 Micro- The Zilog Z80 microprocessor is the central 

processor element of a comprehensive microprocessor 

Family product family. This family works together in 

most applications with minimum requirements 
for additional logic, facilitating the design of 
efficient and cost-effective microcomputer- 
based systems. 

Zilog has designed five components to pro- 
vide extensive support for the Z80 micro- 
processor. These are: 

□ The PIO (Parallel Input/Output) operates in 
both data-byte I/O transfer mode (with 
handshaking) and in bit mode (without 
handshaking). The PIO may be config- 
ured to interface with standard parallel 
peripheral devices such as printers, 
tape punches, and keyboards. 

O The CTC (Counter/Timer Circuit) features 
four programmable 8-bit counter/timers, 



each of which has an 8-bit prescaler. Each 
of the four channels may be configured to 
operate in either counter or timer mode. 

The DMA (Direct Memory Access) con- 
troller provides dual port data transfer 
operations and the ability to terminate data 
transfer as a result of a pattern match. 

The SIO (Serial Input/Output) controller 
offers two channels. It is capable of 
operating in a variety of programmable 
modes for both synchronous and asyn- 
chronous communication, including 
Bi-Synch and SDLC. 

The DART (Dual Asynchronous Receiver/ 
Transmitter) device provides low cost 
asynchronous serial communication. It has 
two channels and a full modem control 
interface. 
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Z80 CPU Figure 4 shows three groups of registers 

Registers within the Z80 CPU. The first group consists of 

duplicate sets of 8-bit registers: a principal set 
and an alternate set (designated by ' [prime], 
e.g., A')- Both sets consist of the Accumula- 
tor Register, the Flag Register, and six 
general-purpose registers. Transfer of data 
between these duplicate sets of registers is 
accomplished by use of "Exchange" instruc- 
tions. The result is faster response to interrupts 
and easy, efficient implementation of such ver- 
satile programming techniques as background- 



foreground data processing. The second set of 
registers consists of six registers with assigned 
functions. These are the I (Interrupt Register), 
the R (Refresh Register), the IX and IY (Index 
Registers), the SP (Stack Pointer), and the PC 
(Program Counter). The third group consists of 
two interrupt status flip-flops, plus an addi- 
tional pair of flip-flops which assists in identi- 
fying the interrupt mode at any particular 
time. Table 1 provides further information on 
these registers. 



MAIN REGISTER SET 



ALTERNATE REGISTER SET 



A ACCUMULATOR 


F FLAG REGISTER 


A' ACCUMULATOR 


F' FLAG REGISTER 


B GENERAL PURPOSE 


C GENERAL PURPOSE 


B' GENERAL PURPOSE 


C GENERAL PURPOSE 


D GENERAL PURPOSE 


E GENERAL PURPOSE 


D' GENERAL PURPOSE 


E' GENERAL PURPOSE 


H GENERAL PURPOSE 


L GENERAL PURPOSE 


H' GENERAL PURPOSE 


L' GENERAL PURPOSE 



INTERRUPT FLIP-FLOPS STATUS 



IX INDEX REGISTER 



IY INDEX REGISTER 



SP STACK POINTER 



PC PROGRAM COUNTER 



I INTERRUPT VECTOR 



R MEMORY REFRESH 



IFF 






FF2 I 


1 ' L_ 


I - 


= INTERRUPTS DISABLED STORES IFF1 -i 

1 = INTERRUPTS ENABLED DURING NMI f 

SERVICE -I 
INTERRUPT MODE FLIP FLOPS 




IMF, 


IMF b 








1 

1 



1 

1 


NTERRUPTMODEO 
NOT USED 
NTERRUPT MODE 1 
NTERRUPT MODE 2 



Figure 4. CPU Registers 



Z80 CPU 
Registers 

(Continued) 





Register 


Size (Bits) 


A, A' 


Accumulator 


8 


F, F' 


Flags 


8 


B, B' 


General Purpose 


8 


C, C 


General Purpose 


8 


D, D' 


General Purpose 


8 


E, E' 


General Purpose 


8 


H, H' 


General Purpose 


8 


L, L' 


General Purpose 


8 



I Interrupt Register 

R Refresh Register 



IX 


Index Register 


16 


IY 


Index Register 


16 


SP 


Stack Pointer 


16 


PC 


Program Counter 


16 


IFF r IFF 2 


Interrupt Enable 


Flip-Flops 


IMFa-IMFb 


Interrupt Mode 


Flip-Flops 



Remarks 

Stores an operand or the results of an operation. 

See Instruction Set. 

Can be used separately or as a 16-bit register with C. 

See B, above. 

Can be used separately or as a 16-bit register with E. 

See D, above. 

Can be used separately or as a 16-bit register with L. 

See H, above. 

Note: The (B,C), (D,E), and (H,L) sets are combined as follows: 
B — High byte C — Low byte 
D — High byte E — Low byte 
H — High byte L — Low byte 

Stores upper eight bits of memory address for vectored interrupt 
processing. 

Provides user-transparent dynamic memory refresh. Automatically 
incremented and placed on the address bus during each 
instruction fetch cycle. 

Used for indexed addressing. 

Same as IX, above. 

Stores addresses or data temporarily. See Push or Pop in instruc- 
tion set. 

Holds address of next instruction. 

Set or reset to indicate interrupt status (see Figure 4). 

Reflect Interrupt mode (see Figure 4). 



Table 1. Z80 CPU Registers 



Interrupts: Th e C PU a ccept s two interrupt input signals: 

General NMI and INT. The NMI is a non-mask able 

Operation interrupt and has the highest priority. INT is a 

lower priority interrupt since it requires that 
interrupts be e nable d i n so ftware in order to 
operate. Either NMI or INT can be connected 
to multiple peripheral devices in a wired-OR 
configuration. 

The Z80 has a single response mode for 
interrupt service for the non- mask able inter- 
rupt. The maskable interrupt, INT, has three 
programmable response modes available. 
These are: 

■ Mode — compatible with the 8080 micro- 
processor. 



■ Mode 1 — Peripheral Interrupt service, for 
use with non-8080/Z80 systems. 

■ Mode 2 — a vectored interrupt scheme, 
usually daisy-chained, for use with Z80 
Family and compatible peripheral devices. 

Th e C PU s ervices interrupts by sampling the 
NMI and INT signals at the rising edge of the 
last clock of an instruction. Further interrupt 
service processing depends upon the type of 
interrupt that was detected. Details on inter- 
rupt responses are shown in the CPU Timing 
Section. 



Interrupts: Non-Maskable Interrupt (NMI). The non- 
Goneral maskable interrupt cannot be disabled by pro- 

Operation gram control and therefo re w ill be accepted at 

(Continued) at all times by the CPU. NMI is usually 

reserved for servicing only the highest priority 
type interrupts, such as that for orderly shut- 
down after power failur e has been detected. 
After rec ognition of the NMI signal (providing 
BUSREQ is not active), the CPU jumps to 
restart location 0066H. Normally, software 
starting at this address contains the interrupt 
service routine. 

Maskable Interrupt (INT). Regardless of the 
interrupt mode set by the user, the Z80 
response to a maskable interrupt input follows 
a common timing cycle. After the interrupt has 
been detected by the CPU (provided that 
interrupts are enabled and BUSREQ is not 
active) a special interrupt processing cycle 
begins . This is a special fetch (Ml) cycle in 
which IQRQ becomes active rather than 
MREQ, as in_a normal Ml cycle. In addition, 
this sp ecial M l cycle is automatically extended 
by two WAIT states, to allow for the time 
required to acknowledge the interrupt request 
and to place the interrupt vector on the bus. 

Mode Interrupt Operation. This mode is 
compatible with the 8080 microprocessor inter- 
rupt service procedures. The interrupting 
device places an instruction on the data bus, 
which is then acted on six times by the CPU. 
This is normally a Restart Instruction, which 
will initiate an unconditional jump to the 
selected one of eight restart locations in page 
zero of memory. 

Mode 1 Interrupt Operation. Mo de 1 o per- 
ation is very similar to that for the NMI. The 
principal difference is that the Mode 1 inter- 
rupt has a vector address of 0038H only. 

Mode 2 Interrupt Operation. This interrupt 
mode has been designed to utilize most effec- 
tively the capabilities of the Z80 microproc- 
essor and its associated peripheral family. The 
interrupting peripheral device selects the 
starting address of the interrupt service 
routine. It does this by placing an 8-bit 
address vector on the data bus during the 
interrupt acknowledge cycle. The high-order 
byte of the interrupt service routine address is 
supplied by the I (Interrupt) register. This flex- 
ibility in selecting the interrupt service routine 
address allows the peripheral device to use 
several different types of service routines. 
These routines may be located at any available 



location in memory. Since the interrupting 
device supplies the low-order byte of the 
2-byte vector, bit (Ao) must be a zero. ' 

Interrupt Priority (Daisy Chaining and 
Nested Interrupts). The interrupt priority of 
each peripheral device is determined by its 
physical location within a daisy-chain config- 
uration. Each device in the chain has an inter- 
rupt enable input line (IEI) and an interrupt 
enable output line (IEO), which is fed to the 
next lower priority device. The first device in 
the daisy chain has its IEI input hardwared to 
a High level. The first device has highest 
priority, while each succeeding device has a 
corresponding lower priority. This arrange- 
ment permits the CPU to select the highest 
priority interrupt from several simultaneously 
interrupting peripherals. 

The interrupting device disables its IEO line 
to the next lower priority peripheral until it has 
been serviced. After servicing, its IEO line is 
raised, allowing lower priority peripherals to 
demand interrupt servicing. 

The Z80 CPU will nest (queue) any pending 
interrupts or interrupts received while a 
selected peripheral is being serviced. 

Interrupt Enable/Disable Operation. Two 

flip-flops, IFFj and IFF2, referred to in the 
register description are used to signal the CPU 
interrupt status. Operation of the two flip-flops 
is described in Table 2. For more details, refer 
to the Z80 CPU Technical Manual and Z80 
Assembly Language Manual. 



Action 



IFFj IFF 2 



Comments 



CPU Reset 

DI instruction 
execution 

EI instruction 
execution 

LD A, I instruction 
execution 

LD A,R instruction 
execution 

Accept NMI 



RETN instruction 
execution 











IFF, 



IFF 2 



Mask able interrupt 
INT disabled 

Mask able interrupt 
INT disabled 

Mask able interrupt 
INT enabled 

IFF 2 - Parity flag 



IFF 2 - Parity flag 

IFFi - IFF 2 
(Mas kabl e inter- 
rupt INT disabled) 

IFF 2 - IFFi at 
comp letion of an 
NMI service 
routine. 
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Table 2. State oi Flip-Flops 



Instruction 
Set 



The Z80 microprocessor has one of the most 
powerful and versatile instruction sets 
available in any 8-bit microprocessor. It 
includes such unique operations as a block 
move for fast, efficient data transfers within 
memory or between memory and I/O. It also 
allows operations on any bit in any location in 
memory. 

The following is a summary of the Z80 
instruction set and shows the assembly 
language mnemonic, the operation, the flag 
status, and gives comments on each instruc- 
tion. The Z80 CPU Technical Manual 
(03-0029-01) and Assembly Language 
Programming Manual (03-0002-01) contain 
significantly more details for programming 
use. 

The instructions are divided into the 
following categories: 

D 8-bit loads 

D 16-bit loads 

D Exchanges, block transfers, and searches 

D 8-bit arithmetic and logic operations 

□ General-purpose arithmetic and CPU 
control 



D 16-bit arithmetic operations 

□ Rotates and shifts 

□ Bit set, reset, and test operations 

□ Jumps 

D Calls, returns, and restarts 

□ Input and output operations 

A variety of addressing modes are 
implemented to permit efficient and fast data 
transfer between various registers, memory 
locations, and input/output devices. These 
addressing modes include: 

D Immediate 

D Immediate extended 

D Modified page zero 

□ Relative 

□ Extended 

□ Indexed 

□ Register 

□ Register indirect 
D Implied 

□ Bit 



8-Bit 




Symbolic 








jFlagi 






Opcod* 




No.oJ 


No.oi M No.oi T 




Load 


Mnemonic 


Operation 


S 


z 




H 




P/V 


N C 


76 543 210 


H.x 


BytM 


CyclM 


Statu 


Commontt 


Group 


LD r, r' 


r — r' 


• 


. 


X 


• 


X 


. 


• • 


01 r r' 




1 


1 


4 


r, r' Reg. 


LDr, n 


r — n 


• 


• 


X 


i • 


X 


• 


• • 


00 r 110 




2 


2 


7 


000 B 






















— n — 










001 c 




LD r, (HL) 


r - (HL) 


• 


• 


X 


• 


X 


• 


• • 


01 r 110 




1 


2 


7 


010 D 




LDr, (IX + d) 


r- (IX + d) 






X 




X 






11 011 101 

01 r 101 

— d — 


DD 


3 


5 


19 


011 E 

100 H 

101 L 




LDr, (IY + d) 


r- (IY + d) 






X 




X 






11 111 101 

01 r 110 

- d- 


FD 


3 


S 


19 


111 A 




LD (HL), r 


(HL) - r 


• 


• 


X 


• 


X 


• 


• • 


01 110 r 




1 


2 


7 






LD(IX + d), r 


(IX + d) - r 






X 




X 






11 011 101 

01 110 r 

- d - 


DD 


3 


5 


19 






LD(IY + d), r 


(IY + d) - r 


' 




X 


' 


X 






11 111 101 

01 110 r 

- d - 


FD 


3 


5 


19 






LD (HL), n 


(HL) - n 


• 


• 


X 


• 


X 


• 


• • 


00 110 110 


36 


2 


3 


10 






LD(IX + d), n 


(IX + d) - n 


* 




X 




X 




* * 


11 011 101 
00 110 110 

- d - 

— n — 


DD 
36 


4 


5 


19 






LD(IY + d), n 


(IY + d) - n 






X 




X 






11 111 101 

oo no no 

- d - 

— n — 


FD 
36 


4 


5 


19 






LD A, (BC) 


A - (BC) 


• 


• 


X 


• 


X 


• 


• • 


00 001 010 


0A 


1 


2 


7 






LD A, (DE) 


A - (DE) 


• 


• 


X 


• 


X 


• 


• • 


00 011 010 


1A 


1 


2 


7 






LD A, (nn) 


A - (nn) 


• 


• 


X 


* 


X 


• 


• • 


00 111 010 


3A 


3 


4 


13 






LD (BC), A 


(BC) - A 


. 


. 


X 


. 


X 


. 


. . 


00 000 010 


02 


1 


2 


7 






LD (DE), A 


(DE) - A 


• 


• 


X 


• 


X 


• 


• • 


00 010 010 


12 


1 


2 


7 






LD (nn), A 


(nn) - A 


• 


• 


X 


• 


X 


• 


* * 


00 110 010 


32 


3 


4 


13 






LDA, I 


A - I 


1 


1 


X 





X 


IFF 


• 


11 101 101 
01 010 111 


ED 
57 


2 


2 


9 






LD A, R 


A - R 


1 


1 


X 





X 


IFF 


• 


11 101 101 
01 011 111 


ED 

5F 


2 


2 


9 






LDI, A 


I - A 


• 


• 


X 


• 


X 


• 


• • 


11 101 101 
01 000 111 


ED 
47 


2 


2 


9 






LDR, A 


R - A 


• 


• 


X 


* 


X 


* 




11 101 101 
01 001 111 


ED 
4F 


2 


2 


9 





NOTES: r, r' means any of the registers A, B, C, D, E, H, L. 

IFF the content of the interrupt enable fhp-flop, (IFF) is 

copied into the P/V (lag. 
For an explanation of Hag notation and symbols for 

mnemonic tables, see Symbolic Notation section 

following tables. 
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16-Bit Load 
Group 



Mnemonic 



Symbolic 
Operation 



Flogs 

H P/V N C 



Opcod* No.ol No.ol M No.ol T 

76 M3 210 Hox Byt« CydM SlaiM 



LD dd, nn 
LD IX, nn 

LD IY, nn 



LD (nn), IX 



LD (nn), IY 



LD SP, HL 
LD SP, IX 



LD SP, IY 
PUSH qq 



POPqq 



dd — nn 
IX — nn 

IY - nn 



LDHL, (nn) H-(nn+l) 
L - (nn) 



LDdd, (nn) ddH-(nn+l) 
ddL - (nn) 



LDIX, (nn) IXH-(nn+l) 

IX L - (nn) 



LDIY. (nn) IY H -(nn+l) 

IY L - (nn) 



LD(nn), HL (nn + l)-H 
(nn) - L 



LD(nn), dd (nn+l)-ddH 
(nn) - ddL 



(nn + 1) - IXh 
(nn) - IX L 



(nn+l)-IY H 
(nn) - IY L 



SP- HL 
SP- IX 

SP- IY 

(SP-2) - qq L 
(SP-l)-qq H 
SP- SP -2 
(SP-2) - IX L 
(SP-D- IX H 
SP - SP -2 
(SP-2) - IY L 
(SP-D-IYh 
SP - SP -2 
qq H -(SP+l) 
QQL ~ (SP) 
SP - SP +2 
IX H -(SP+1) 
IX L - (SP) 
SP - SP +2 
IY H -(SP + 1) 
IY L - (SP) 
SP - SP +2 



X • X 

X • X 

X • X 

X • X 

X • X 

X • X 



X • X 

X • X 

X • X 

X • X 

X • X 

X • X 



00 ddO 001 

— n — 

— n — 

11 011 101 DD 
00 100 001 21 

— n — 

— n — 

11 111 101 FD 
00 100 001 21 

— n — 

00 101 010 2A 

— n — 

11 101 101 ED 

01 ddl 011 

— n — 

— n — 

11 011 101 DD 
00 101 010 2A 

— n — 

11 111 101 FD 
00 101 010 2A 

— n — 

00 100 010 22 

— n — 

— n — 

11 101 101 ED 

01 ddO 011 

— n — 

— n — 

11 011 101 DD 
00 10O 010 22 

— n — 

— n — 

11 111 101 FD 
00 100 010 22 

— n — 

— n — 

11 111 001 F9 
11 011 101 DD 
11 111 001 F9 
11 111 101 FD 
11 HI 001 F9 
11 qqO 101 



11 011 101 DD 
11 10O 101 E5 



11 111 101 FD 
11 10O 101 E5 



00 


BC 


01 


DE 


10 


HL 


11 


SP 



6 20 

5 16 

6 20 

6 20 



11 qqO 001 



11 011 101 DD 
11 10O 001 El 



11 111 101 FD 
11 100 001 El 



1 


6 






2 


10 






2 


10 










qq. 


Pair 


3 


11 


00 


BC 






01 


DE 






10 


HL 


4 


15 


11 


AF 


4 


15 






3 


10 







NOTES: dd is any of the register pairs BC. DE, HL, SP. 
qq is any of the register pairs AF, BC, DE, HL. 

(PAIR)h, (PAIR)l refer to high order and low order eight bits of the register pair respectively, 
e.g., BCl = C, AFh ■ A. 



S3 

O 

o 

a 



Exchange. 


EXDE, 


HL 


DE - HL 


Block 


EXAF, 
EXX 


AF' 


AF - AF' 
BC - BC 


Transfer, 






DE - DE' 


Block Search 


EX(SP) 


HL 


HL - HL' 
H - (SP + 1) 


Groups 






L - (SP) 




EX (SP) 


IX 


IX H -(SP+1) 
IX L - (SP) 




EX(SP) 


IY 


IY H -(SP+1) 
1Y L - (SP) 




LDI 




(DE) - (HL) 
DE - DE + 1 
HL- HL+1 
BC- BC-1 




LDIR 




(DE) - (HL) 
DE - DE+1 
HL - HL+1 
BC - BC-1 
Repeat until 
BC = 



X • X • • 

X • X • • 

X • X • • 

© 

X X I 



X X. 



11 101 011 EB 
00 001 000 08 
11 Oil 001 D9 



11 100 011 E3 

11 Oil 101 DD 

11 100 011 E3 

11 111 101 FD 

11 100 011 E3 

11 101 101 ED 

10 100 000 A0 



11 101 101 ED 
10 110 000 B0 



1 


4 


Register bank and 
auxiliary register 
bank exchange 


5 


19 




6 


23 




6 


23 




4 


16 


Load (HL) into 
(DE), increment 
the pointers and 
decrement the byte 
counter (BC) 


S 


21 


If BC * 


4 


16 


If BC -0 



NOTE: 0P/V flag is il the result of BC- 1 =0. otherwise P/V = 1. 
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Exchange. 

Block 

Transfer, 

Block Search 

Groups 

(Continued) 



Symbolic 
Operation 



Flags 

H P/V N C 



Opcod* No.oi No.oi M No.oi T 

76 543 210 H»x Bytst Cyclei Statu 



(DE) - (HL) 
DE - DE-1 
HL -HL-1 
BC - BC - 1 

(DE) - (HL) 
DE - DE-1 
HL - HL-1 
BC - BC - 1 
Repeat until 
BC = 

A - (HL) 
HL -HL+1 
BC - BC - 1 

A - (HL) 

HL - HL+1 
BC - BC - 1 
Repeat until 
A = (HL) or 
BC = 

A - (HL) 
HL - HL-1 
BC - BC - 1 

A - (HL) 

HL - HL-1 
BC - BC - 1 
Repeat until 
A = (HL) or 
BC = 



® 



X X 



© 



© 



© 



© 



11 101 101 ED 
10 101 000 A8 



11 101 101 ED 
10 111 000 B8 



11 101 101 ED 
10 100 001 Al 



11 101 101 ED 
10 110 001 Bl 



11 101 101 ED 
10 101 001 A9 



11 101 101 ED 
10 111 001 B9 



If BC * 
If BC = 



21 


If BC * and 




A * (HL) 


16 


If BC = or 




A = (HL) 



If BC * and 
A * (HL) 

If BC = or 
A = (HL) 



NOTES: © P/V Hag is if the result of BC - 1 =0. otherwise P/V 
Q) Z flag is 1 if A = (HL), otherwise Z = 0. 



8-Bit 


ADD A, r A - A + r 1 


1 1 X 


Arithmetic 


ADD A, n A - A + n 1 


1 1 X 


and Logical 






Group 


ADD A, (HL) A - A + (HL) 


1 t X 




ADDA, (IX + d) A - A + (IX + d) ; 


1 1 X 



ADD A, (IY + d) A - A + (IY + d) 



ADC A, s 




A - A + s + CY 


SUBs 




A - A-s 


SBC A, s 




A - A-s-CY 


ANDs 




A - A A s 


OR s 




A - A V s 


XORs 




A-A»s 


CPs 




A-s 


INCr 




r - r + 1 


INC (HL) 




(HL) -(HD+1 


INC (IX + 


d) 


(IX + d)- 
(IX + d)+l 


INC (IY + 


d) 


(IY + d)- 
(IY + d)+l 



I 
I 



I X V I 



t I X I X V 



11 [oool 110 

- n — 

IQfOOOl 1 10 
11 011 101 

lolooolno 

- d - 
11 111 101 

10 [Pool 110 

- d - 

foon 

foul 
flool 
fTTol 
QU 
ED 
oo r frag 

00 i 10 flool 
ii on ioi 
oo no [raj 

-ti- 
ll 111 101 

oo no [raj 

- d - 



1 


4 


r 


Reg. 


2 


7 


000 


B 






001 


C 






010 


D 


2 


7 


an 


E 


5 


19 


100 


H 



is any of r, n, 
(HL), (IX + d), 
(IY + d) as shown 
for ADD instruction. 
The indicated bits 
replace the [tXJO] in 
the ADD set above. 



m is any of r, (HL), 
(IX + d), (IY + d) 
as shown for INC. 
DEC same format 
and state s as INC. 
Replace fjo5| with 
fToil in opcode. 
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General- 
Purpose 
Arithmetic 
and 

CPU Control 
Groups 



Symbolic 
Operation 



Flags 

H P/V N C 



Opcode 
78 S43 210 Hex 



No.oi 
Bytes 



No.oi M No.oi T 
Cycles States 



Converts ace. content 
Into packed BCD 
following add or 
subtract with packed 
BCD operands. 

A - A 



00 100 111 27 



CCF 


CY - CY 


SCF 


CY - 1 


NOP 


No operation 


HALT 


CPU halted 


DI * 


IFF - 


EI * 


IFF - 1 


IM0 


Set interrupt 




mode 


IM 1 


Set interrupt 




mode 1 


IM2 


Set interrupt 




mode 2 



X 


1 


X 


• 1 • 


00 101 111 2F 


X 


1 


X 


V 1 1 


11 101 101 ED 
01 000 100 44 


X 


X 


X 


• 1 


00 111 111 3F 


X 





X 


• 1 


00 110 111 37 


X 


• 


X 


• • • 


00 000 000 00 


X 


• 


X 


• • • 


01 110 110 76 


X 


• 


X 


• • • 


11 110 011 F3 


X 


• 


X 


• • • 


11 111 011 FB 


X 


• 


X 


• • • 


11 101 101 ED 
01 000 110 46 


X 


• 


X 


• • • 


11 101 101 ED 
01 010 110 56 


X 


• 


X 


* • • 


11 101 101 ED 
01 011 110 5E 



Decimal adjust 
accumulator. 



Complement 

accumulator (one' 

complement). 
Negate ace. (two's 

complement). 
Complement carry 

flag. 
Set carry flag. 



NOTES: IFF indicates the interrupt enable flip-flop. 
CY indicates the carry flip-flop. 
* indicates interrupts are not sampled at the end of EI c 



LSI 

00 

o 

o 

•a 
a 



16-Bit 


ADD HL, ss 


HL - HL + ss 




• 


• X 


X 


X 


. 


1 


00 ssl 001 




1 


Arithmetic 


ADC HL, ss 


HL - HL + SS4 


CY 


1 


1 X 


X 


X 


V 


1 


11 101 101 


ED 


2 


Group 




















01 ssl 010 








SBC HL, ss 


HL - HL-ss- 


CY 


t 


1 X 


X 


X 


V 


1 1 


11 101 101 
01 ssO 010 


ED 


2 




ADD IX, pp 


IX - IX + pp 






« X 


X 


X 




1 


11 011 101 
01 ppl 001 


DD 


2 




ADD IY, rr 


IY - IY + rr 




• 


• X 


X 


X 


• 


I 


11 111 101 
00 rrl 001 


FD 


2 




INCss 


ss - ss + 1 






■ X 




X 




. . 


00 ssO 011 




1 




INC IX 


IX - IX + 1 






• X 


• 


X 


• 


• • 


11 011 101 
00 100 011 


DD 
23 


2 




INCIY 


IY - IY + 1 






• X 


• 


X 


• 


• • 


11 111 101 
00 100 011 


FD 
23 


2 




DECss 


ss - ss - 1 






• X 


• 


X 


• 


• • 


00 ssl 011 




1 




DEC IX 


IX - IX - 1 






■ X 


• 


X 


• 


* • 


11 011 101 
00 101 011 


DD 
2B 


2 




DEC1Y 


IY - IY - 1 




• 


• X 


• 


X 


• 


• • 


11 111 101 

00 101 on 


FD 
2B 


2 



00 


BC 


01 


DE 


10 


HL 


11 


SP 


PP 


Reg. 


00 


BC 


01 


DE 


10 


IX 


11 


SP 


rr 


Reg. 


00 


BC 


01 


DE 


10 


IY 


11 


SP 



NOTES: ss is any ol Ihe register pairs BC. DE. 111.. SP. 
pp is any d the register pairs BC, DE. IX. SP. 
rr is any ol the register pairs BC, DE. IY. SP. 



Rotate and 
Shift Group 



RLCA 

RLA 

RRCA 

RRA 

RLCr 
RLC(HL) 




,(HL).(IX + d),(IY + d) 



m-r,(HL),(IX + d).(IY + d) 

RRC m L | 7 |-L[cy] 

m-r,(HL),(IX + d),(lY + d) 



RLm 



X X • 1 00 000 111 07 1 

X X • I 00 010 111 17 1 

X X • 1 00 001 111 OF 1 

X X • 1 00 011 111 IF 1 



I I X X P 1 

I 1 X X P 1 

I I X X ' P 1 

t I X X P 1 

1 I X X P I 

1 I X X P I 



001 on cb 

00 000 r 

001 on cb 
00 000 110 

011 101 DD 

001 on cb 

- d - 

00 000 no 

111 101 FD 

001 on cb 

- d - 

00 000 no 

010 



4 


Rotate lelt circular 




accumulator. 


4 


Rotate lelt 




accumulator. 


4 


Rotate right circula 




accumulator. 


4 


Rotate right 




accumulator. 


3 


Rotate lelt circular 




register r. 


IS 


r Reg. 




000 B 




001 C 




010 D 




on e 




100 H 




101 L 




111 A 



Instruction format 
and states are as 
shown for RLCs. 
To form new 
opcode replace 
000 or RLCs 
with shown code. 
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Rotate and 
Shift Group 

(Continued) 



Symbolic 
Operation 



Flags Opcode No.oi No.oi M No.oi T 

S Z H P/V N C 76 543 210 H*x BytM Cycle* Statu 



RRm 
SLA m 
SRA m 
SRLm 
RLD 



L- i 7 — ° I — -I^V I I X X P t 

m-r.(HL),(IX + d),(IY + d) 



[cy] 1 t. f —° | I X X P I 

m-r,(HL),(IX + d),(IY + d) 



|~l i 7 "° I *^ t I X X P I 
m»r.(HL),(IX + d),(IY + d) 



° H ' -0 I -[£v] , t X X P ! 

m-r,(HL),(IX + d),(IY + d) 

|r-«|3-o| 1 ?• -■« 1 3 -o| , t X X P • 



| y - •« 1 3 - o | , i X X P 



loTil 




fiool 




poll 




fim 




11 101 101 
01 101 111 


ED 
6F 


11 101 101 
01 100 111 


ED 
67 



Rotate digit left and 


ri< 


ght between 


th 


e accumulator 


and location (HL). 


The content of the 


upper half of 


th 


e accumulator is 


unaffected . 


r 


Reg. 


660 


B 


001 


C 


010 


D 


011 


E 


100 


H 


101 


L 


111 


A 


b 


Bit Tested 


000 





001 


1 


010 


2 


011 


3 


100 


4 


101 


5 


110 


6 


111 


7 



Bit Set, Reset bit b, r 

and Test 

Group 



BIT b, (HL) Z - (HL)b 
BITb, (IX + d) b Z- (IxTd)b 



BITb, (IY + d) b Z- (IY + d) b 



SET b. r r b - 1 

SET b, (HL) (HL) b - 1 

SETb, (IX + d) (IX + d)b- 1 

SETb, (IY + d) (IY + d)b- 1 



RES b, m mb — 

m - r, (HL), 
(IX + d), 
(IY + d) 



X I X 1 X X 

X I X 1 X X 

X I X 1 X X 

X I X 1 X X 



X • X 
X • X 
X • X 



11 001 011 CB 

01 b r 

11 001 011 CB 

01 b 110 

11 011 101 DD 

11 001 011 CB 

- d - 
01 b 110 

11 111 101 FD 
11 001 Oil CB 

- d - 
01 b 110 



11 001 011 CB 

11 001 011 CB 
HD b 110 
11 011 101 DD 
11 001 Oil CB 

- d - 
[H] b 110 

11 111 101 FD 

11 001 Oil CB 

- d - 
QT] b 110 

m 



To form new 
opcode replace 
O of SET b, s 
with [JO]. Flags 
and time states fo 
SET instruction. 





NOTES: The n 


otation m^j indicates 


bit b (0 to 71 c 


>"" 


















Jump 


JPnn 


PC - nn 




. 


• X • 


X • • • 


11 


000 011 


C3 


3 


3 


10 




Group 














_ 


n — 










cc Condition 




JP cc, nn 


If condition cc 
true PC - nn, 
otherwise 
continue 


is 




• X • 


X • • • 


11 


cc 010 
n — 




3 


3 


10 


000 NZ non-zero 

001 Z zero 

010 NC non-carry 

011 C carry 

100 PO parity odd 

101 PE parity even 

1 10 P sign positive 




IRe 


PC - PC + e 




• 


• X • 


X • • • 


00 011 000 


IB 


2 


3 


12 


111 M sign negative 
















— 


e-2 - 














IRC, e 


If C = 0, 
continue 
If C = 1, 
PC - PC + e 






• X • 


X • • • 


00 


111 000 
e-2 - 


38 


2 
2 


2 
3 


7 
12 


If condition not met. 
If condition is met. 




IR NC, e 


If C = 1, 
continue 
If C = 0, 
PC - PC + e 






• X • 


X • • • 


00 


110 000 
e-2 - 


30 


2 
2 


2 

3 


7 
12 


If condition not met. 
If condition is met. 




IPZ, e 


HZ = 
continue 
If Z = 1 , 
PC - PC + e 






• X • 


X • • • 


00 


101 000 
e-2 - 


28 


2 
2 


2 

3 


7 
12 


If condition not met. 
If condition is met. 




IR NZ, e 


If Z = 1 , 
continue 
If Z = 0, 
PC - PC + e 






• X • 


X • • • 


00 


100 000 
e-2 - 


20 


2 
2 


2 

3 


7 
12 


If condition not met. 
If condition is met. 




JP (HL) 


PC - HL 




* 


• X • 


X • • • 


11 


101 001 


E9 


1 


1 


4 






JP (IX) 


PC - IX 






• X • 


X • • • 


11 
11 


011 101 
101 001 


DD 
E9 


2 


2 


8 
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Jump Group 

(Continued) MB,monle 



IP (IY) 





Symbolic 










Operation 


S 


Z 




PC 


- IY 


. • 


• 


X 


B- 


B-l • 


. 


. 


X 


UB 


- 0. 








continue 








If B 


* 0. 








PC 


- PC + e 









Flagi 



Opcode 



No.oi No.ol M H0.0I T 



P/V N C 71 Hi 210 Hex BytM Crcle* Sloiee 



11 111 101 FD 


2 


2 


8 




11 101 001 £9 










00 010 000 10 


2 


2 


8 


If B - 0. 


- e-2 - 












2 


3 


13 


If B # 0. 



NOTES: • repreienti the extension In the relative addreuing mode. 

e ii a eigned two'i complement number in the range < - 126, 129 > . 
e - 2 in the opcode provide! en effective eddreti of pc + e «■ PC Ii Incremented 
by 2 prior to the addition of e. 



Call and 
Return Group 



CALLnn 


(SP-I)-PCh 




(SP-2)-PC L 




PC - nn 


CALL cc, nn 


If condition 




cc is false 




continue, 




otherwise same as 




CALLnn 


RET 


PC L -(SP) 




PC H -(SP + l) 


RETcc 


If condition 




cc is false 




continue, 




otherwise 




same as 




RET 


RETI 


Return from 




Interrupt 


RETNl 


Return from 




non-maskable 




interrupt 


RSTp 


■ (SP-1) -PC H 




(SP-2) -PC L 




PCh-O 




PCl-P 



X • X 
X • X 



X • X 
X • X 



11 001 101 


CD 


3 


5 


17 




— n — 












— n — 












11 cclOO 




3 


3 


10 


If cc is false. 


— n — 












— n — 




3 


5 


17 


If cc is true. 



11 001 001 C9 1 

11 ccOOO 1 
1 



11 101 101 ED 2 

01 001 101 4D 

11 101 101 ED 2 

01 000 101 45 



If cc is true. 

cc Condition 

000 N2. non-zero 

001 Z zero 

010 NC non-carry 

011 C carry 

100 PO parity odd 

101 PE parity even 

110 P sign positive 

111 M sign negative 

t P 



000 00H 

001 08H 

010 10H 

011 18H 

100 20H 

101 28H 

110 30H 

111 38H 



e 
o 

a 



NOTE: 'RETN loads IFF 2 - IFF] 



Input and in a, m 

Output Group 



A-(n) 



IN r, (C) 


r-(C) 




if r = 110 only the 




flags will be affected 


INI 


(HL) - (C) 




B -B-l 




HL - HL + 1 


INIR 


(HL) - (C) 




B -B-l 




HL - HL + 1 




Repeat until 




B = 


IND 


(HL) - (C) 




B - B -1 




HL - HL-1 


INDR 


(HL) - (C) 




B - B-l 




HL - HL-1 




Repeat until 




B = 


OUT (n), A 


(n) -A 


OUT (C), r 


(C) -r 


OUTI 


(C) - (HL) 




B - B-l 




HL - HL + 1 


OTIR 


(C) - (HL) 




B - B-l 




HL - HL + 1 




Repeat until 




B = 


OUTD 


(C) - (HL) 




B - B-l 




HL- HL-1 



o 



CD 



CD 



© 



I X X X X 1 



11 011 011 DB 
— n — 
11 101 101 ED 
01 r 000 



11 101 101 ED 
10 100 010 A2 



11 101 101 ED 
10 111 010 BA 



11 010 011 D3 
— n — 
11 101 101 ED 
01 r 001 



11 101 101 ED 
10 100 011 A3 



11 101 101 ED 
10 110 011 B3 



11 101 101 ED 
10 101 011 AB 



5 
(HB#0) 



(HB = 0) 
3 



(II B#0) 

4 
(If B = 0) 



11 101 101 ED 2 5 21 
10 110 010 B2 (IfB*0) 

2 4 16 
(IIB = 0) 



11 101 101 ED 
10 101 010 AA 



n to A<) - A7 
Ace. to Ag - A15 
C to Ao - A7 
BtoAg - A15 



C to Ao - A7 
B to A a - A15 



C to Aq - A7 
B to As - A15 



C to Ao - A7 
B to Ag - A15 



C to Ao - A7 
B to A 8 - A15 



n to Aq - A7 
Ace. to As - A]5 
C to Aq - A7 
B to Ag - A15 

C to Ao - A7 
B to Ag - A15 

C to Ao - A7 
B to Ag - A15 



C to Ao - A7 
B to Ag - A15 



NOTE: Q II the result of B- 1 is zero the Z llag is set. otherwise it is reset. 



2001-001 
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Input and 

Output Group Mn * monle 

(Continued) otdr 



Symbolic 
Operation 



Flags 

H P/V N 



Opcod. No.oi Ho.oi M No.of T 

78 543 210 H.x Byte* Cycle* Slain 



(C) - (HL) 
B -B-l 
HL - HL- 
Repeat until 
B = 



1 X X X X 1 



11 101 101 ED 
10 111 Oil 



5 
(IfB*0) 



(I1B = 0) 



C to Ao - A7 
Bto As - A]s 



Summary of 

Flag 

Operation 



Instruction 



»7 
S Z 



DO 
H P/V N C 



ADD A, a; ADC A, a 

SUB s; SBC A, s; CP s; NEG 

AND a 

OR s, XOR a 

INCs 

DEC a- 

ADD DD, sa 

ADC HL, sa 

SBC HL, sa 

RLA, RLCA, RRA; RRCA 

RL m; RLC m; RR m; 

RRC m; SLA m; 

SRA m; SRL m 
RLD; RRD 
DAA 
CPL 
SCF 
CCF 
IN r (C) 

INI, IND, OUTI; OUTD 
INIR; INDR; OTIR; OTDR 
LDI; LDD 
LDIR; LDDR 
CPI; CPIR; CPD; CPDR 

LDA, I, LDA, R 
BIT b, s 



:) 



8-bit add or add with carry. 

8-bit subtract, subtract with carry, compare and negate accumulator. 

Logical operations. 
8-bit increment. 
8-bit decrement. 
16-bit add. 

16-bit add with carry. 
16-bit subtract with carry. 
Rotate accumulator. 
Rotate and shift locations. 



Rotate digit left and right. 

Decimal adjust accumulator. 

Complement accumulator. 

Set carry. 

Complement carry. 

Input register indirect. 

Block input and output. Z = if B * otherwise Z 



Block transfer instructions. P/V 



1 if BC * 0, otherwise P/V = 0. 
0. P/V 



X IFF 

1 X X 



Block search instructions. Z ~ 1 if A = (HL), otherwise Z 

if BC # 0, otherwise P/V = 0. 
The content of the interrupt enable flip-llop (IFF) is copied into the P/V flag. 
The state of bit b of location s is copied into the Z flag. 



Symbolic Symbol Operation 

Notation S S '9 n fla( 3' S = 1 if the MSB of the result is 1. 

Z Zero flag. Z = 1 if the result of the operation is 0. 

P/V Parity or overflow flag. Parity (P) and overflow 

(V) share the same flag. Logical operations affect 
this flag with the parity of the result while 
arithmetic operations affect this flag with the 
overflow of the result. If P/V holds parity, P/V = 
1 if the result of the operation is even, P/V = if 
result is ;dd. If P/V holds overflow, P/V = 1 if 
the resu'' ■.■• the operation produced an overflow. 
;. H Half-cair lag. H = 1 if the add or subtract 

operatic" produced a carry into or borrow from 
bit 4 of :>!'' accumulator. 

N Add/Su' ' ict flag. N = 1 if the previous opera- 

tion was lubtract. 

H & N H and K : '.-.:,gs are used in conjunction with the 

decimal : ust instruction (DAA) to properly cor- 
rect the .It into packed BCD format following 
addition iubtraction using operands with 
packed I . D format. 

C Carry/Li, ■.: flag. C = 1 if the operation produced 

a carry fi .m the MSB of the operand or result. 



Symbol 
I 



Operation 

The flag is affected according to the result of the 

operation. 

The flag is unchanged by the operation. 

The flag is reset by the operation. 

The flag is set by the operation. 

The flag is a "don't care." 

P/V flag affected according to the overflow result 

of the operation. 

P/V flag affected according to the parity result of 

the operation. 

Any one of the CPU registers A, B, C, D, E, H, L. 

Any 8-bit location for all the addressing modes 

allowed for the particular instruction. 

Any 16-bit location for all the addressing modes 

allowed for that instruction. 

Any one of the two index registers IX or IY. 

Refresh counter. 

8-bit value in range < 0, 255 > . 

16-bit value in range < 0, 65535 > . 
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Pin A0-A15. Address Bus (output, active High, 

Descriptions 3-state). A0-A15 form a 16-bit address bus. The 
Address Bus provides the address for memory 
data bus exchanges (up to 64K bytes) and for 
I/O device exchanges. 

BUSACK. Bus Acknowledge (output, active 
Low). Bus Acknowledge indicates to the 
reguesting device that the C PU add r ess bus , 
dat a bus, an d control signals MREQ, IORQ, 
RD, and WR have entered their high- 
impedance states. The external circuitry 
can now control these lines. 



BUSREQ. Bus Bequest (input, active L ow). 
Bus Reguest has a higher priority than NMI 
and is always recog nized at th e end of the cur- 
rent machine cycle. BUSREQ forces the CPU 
addres s bus, d ata bus, and control signals 
MREQ, IORQ, RD, and WR to go to a high- 
impedance state so that othe r devices can 
control these lines. BUSREQ is normally wire- 
ORed and reguires an extern al pullup for 
these applications. Extended BUSREQ 
periods due to extensive DMA operations can 
prevent the CPU from properly refreshing 
dynamic RAMs. 

D0-D7. Data Bus (input/output, active High, 
3-state). D0-D7 constitute an 8-bit bidirectional 
data bus, used for data exchanges with 
memory and I/O. 

HALT. Halt State (output, active Low). HALT 
indicates that the CPU has executed a Halt 
instruction and is awaiting either a non- 
maskable or a maskable interrupt (with the 
mask enabled) before operation can resume. 
While halted, the CPU executes NOPs to 
maintain memory refresh. 

INT. Interrupt Request (input, active Low). 
Interrupt Reguest is generated by I/O devices. 
The CPU honors a reguest at the end of the 
current instruction if the internal software- 
controlle d int errupt enable flip-flop (IFF) is 
enabled. INT is normally wire-ORed and 
reguires an external pullup for these 
applications. 

IORQ. Input/ Outpu t Bequest (output, active 
Low, 3-state). IORQ indicates that the lower 
half of the address bus holds a valid I/O 

addre ss for an I/O read or write operation. 

IORQ is also generated concurrently with Ml 
during an interrupt acknowledge cycle to indi- 
cate that an interrupt response vector can be 



placed on the data bus. 

Ml . Machine Cyc le One (output, active Low). 
Ml, together with MREQ, indicates that the 
current machine cycle is the opcode fetch 
cycl e of an instruction execution. Ml, together 
with IORQ, indicates an interrupt acknowledge 
cycle. 



MREQ. Mem ory Beq uest (output, active 
Low, 3-state). MREQ indicates that the address 
bus holds a valid address for a memory read or 
memory write operation. 

NMI. Non- Maskable Interrupt (input, acti ve 

Low). NMI has a higher priority than INT. NMI 
is always recognized at the end of the current 
instruction, independent of the 
status of the interrupt enable flip-flop, and 
automatically forces the CPU to restart at 
location 0066H. 

RD. Memory Bead (output, active Low, 
3-state). RD indicates that the CPU wants to 
read data from memory or an I/O device. The 
addressed I/O device or memory should use 
this signal to gate data onto the CPU data bus. 

RESET. Beset (input, active Low). RESET 
initializes the CPU as follows: it resets the 
interrupt enable flip-flop, clears the PC and 
Registers I and R, and sets the interrupt status 
to Mode 0. During reset time, the address and 
data bus go to a high-impedance state, and all 
control o utput si gnals go to the inactive state. 
Note that RESET must be active for a minimum 
of three full clock cycles before the reset 
operation is complete. 

RFSH. Befres h (outp ut, active Low). RFSH, 
together with MREQ, indicates that the lower 
seven bits of the system's address bus can be 
used as a refresh address io the system's 
dynamic memories. 



WAIT. Wait (input, active Low). WAIT 
indicates to the CPU that the addressed mem- 
ory or I/O devices are not ready for a data 
transfer. The CPU continues to enter a Wait 
state a s long as this signal is active. Extended 
WAIT periods can prevent the CPU from 
refreshing dynamic memory properly. 

WR. Me mor y Write (output, active Low, 
3-state). WR indicates that the CPU data bus 
holds valid data to be stored at the addressed 
memory or I/O location. 



N 

00 

e 

o 

■a 
a 
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CPU Timing The Z80 CPU executes instructions by pro- 

ceeding through a specific sequence of opera- 
tions: 

■ Memory read or write 

■ I/O device read or write 

■ Interrupt acknowledge 



The basic clock period is referred to as a 
T time or cycle, and three or more T cycles 
make up a machine cycle (Ml, M2 or M3 for 
instance). Machine cycles can be extended 
either by the CPU automatically inserting one 
or more Wait states or by the insertion of one 
or more Wait states by the user. 



Instruction Opcode Fetch. The CPU places 
the contents of the Program Counter (PC) on 
the address bus at the start of the cycle (Figure 
5). Ap proximately one-half clock cycle later, 
MREQ goes active. The falling edge of MREQ 
can be used directly as a Chip Enable to dyna- 
mic memories. When active, RD indicates that 
the memory data can be enabled onto the CPU 



data bus. 

The CPU samples the WAIT input with the 
rising edge of clock state T3. During clock 
states T3 and T4 of an Ml cycle dynamic RAM 
refresh can occur while the CPU starts 
decoding and executing the instruction. When 
the Refresh Control signal becomes active, 
refreshing of dynamic memory can take place. 







-m^zx 



-fj- 



U-H-® 



NOTE: T w -Wait cycle added when necessary for slow ancilliary devices. 

Figure 5. Instruction Opcode Fetch 
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CPU Non- Maskable Interrupt Request Cyclo. 

Timing NMI is sampled at the sa me t ime as the 

(Continued) maskable interrupt input INT but has higher 

priority and cannot be disabled under software 
control. The subsequent timing is similar to 



that of a normal memory read operation except 
that data put on the bus by the memory is 
ignored. The CPU instead execut es a r estart 
(RST) operation and jumps to the NMI service 
routine located at address 0066H (Figure 9). 



-LAST M CYCLE - 
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'Although NMI is an asynchronous input, to guara ntee its being 
recognized on the following machine cycle, NMI's falling edge 



must occur no later tl i . the rising edge of the clock cycle 
preceding Ttj\st. 



Figure 9. Non-Maskable Interrupt Request Op ion 



Bus Req uest/Ack nowledge Cyclo. The CPU 

samples'BUSREQ with the rising edge of the 
last cl ock period of any machine cycle (Figure 

10). If BUSREQ is active, t he CP U sets its 

address, data, and MREQ, IORQ, RD, and WR 



lines to a high ■ 'pedance state with the rising 
edge of the ne ' -:lock pulse. At that time, any 
external device- . an take control of these lines, 
usually to transier data between memory and. 
I/O devices. 



NOTE: Tl= Last state of any M cycle. 




Tx = An arbitrary clock cycle used by requesting device. 



Figure 10. Bus Request/Acknowledge Cycle 



2005-0218, 886 
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CPU Halt Ackn owled ge Cycle. When the CPU 

Timing receives a HALT inst ruct ion , it e xecutes NOP 

(Continued) states until either an INT or NMI input is 



received. When in the Halt state, the HALT 
output is active and remains so until an inter- 
rupt is processed (Figure 11). 



■ 4 '1 '2 >3 <4 M '2 

i\f\f\j\j\r\f\ 



HALT \ - 
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NOTE: INT will also force a Halt exit. 



*See note, Figure 9. 
Figure 11. Halt Acknowledge Cycle 



Reset Cycle. RESET must be active for at least inactive, two internal T cycles are consumed 
three clock cycles fo r the CP U to properly before the CPU re sumes normal processing 

accept it. As long as RESET remains active', the operation. RESET clears the PC register, so the 
address and data buses flo at, and the control first opcode fetch will be to location 0000 

outputs are inactive. Once RESET goes - (Figure 12). 
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Figure 12. Reset Cycle 
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AC 

Charac- 
teristics 


Number 


Symbol 


Parameter 


Z80 CPU 
Min Max 
(ns) (ns) 


Z80A CPU 
Min Max 
(ns) (ns) 


Z80B CPU 
Min Max 
(ns) (ns) 




1 


TcC 


Clock Cycle Time 


400* 




250* 




165* 






2 


TwCh 


Clock Pulse Width (High) 


180* 




110* 




65* 






3 


TwCl 


Clock Pulse Width (Low) 


180 


2000 


110 


2000 


65 


2000 




4 

5 — 
6 


TfC 


Clock Fall Time 


— 


30 


— 


30 


- 


20 




TdCr(A) 


Clock t to Address Valid Delay 


— 


JU 
145 


— 


- jU 

110 





■■— 20 
90 




7 


TdA(MREQf) 


Address Valid to MREQ 
1 Delay 


125* 


— 


65* 


— 


35* 


— 




8 


TdCf(MREQf) 


Clock 1 to MREQ I Delay 


— 


100 


— 


85 


— 


70 




9 

io- 


TdCr(MREQr) 
-TwMREQh 


Clock t to MREQ t Delay 




100 


— 


85 


— 


70 




■ MnliiJ rulse Width Uuyh; 


■■■ 1/U ■ 




110 ■ 




CD 






ii 

12 


TwMREQl 
TdCf(MREQr) 


MREQ Pulse Width (Low) 


360* 


100 


220* 


85 


135* 


- 




Clock 1 to MREQ t Delay 


70 




13 


TdCf(RDf) 


Clock I to RD I Delay 


— 


130 


— 


95 


— 


80 




14 


TdCr(RDr) 


Clock ttoffit Delay 


— 


100 


— 


85 


— 


70 




15 — 




- Data Setup Time to Clock t 


— 50- 




35- 




















16 
17 


ThD(RDr) 
TsWAIT(Cf) 


Data Hold Time to RD t 


70 





70 





60 







WAIT Setup Time to Clock 1 


— 




18 


ThWAIT(Cf) 


WAIT Hold Time after Clock I 


— 





— 





— 







19 
20 — 


TdCr(Mlf) 
-TdCr(Mlr) 


Clock 1 to Ml 1 Delay 


— 


130 


— 


100 


— 


80 
















uu 




21 


TdCr(RFSHf) 


Clock t to RFSH 1 Delay 


— 


180 


— 


130 


— 


110 




22 


TdCr(RFSHr) 


Clock t to RFSH t Delay 


— 


150 


— ' 


120 


— 


100 




23 


TdCf(RDr) 


Clock 1 to RD t Delay 


— 


110 


— 


85 


— 


70 




24 


TdCr(RDf) 


Clock t to RD 1 Delay 


— 


100 


— 


85 


— 


70 




25 — 

26 
27 




- Data Setup to Clock I during 

Mj, M3, M4 or M5 Cycles 


— 60- 
320* 














TdA(IORQf) 
TdCr(IORQf) 


90 


180* 


75 


110* 






Address Stable prior to IORQ 1 


— 




Clock t to IORQ I Delay 


65 




28 


TdCf(IORQr) 


Clock 1 to IORQ t Delay 


— 


110 


— 


85 


— 


70 




29 
30- 


■ TdD(WRf) 
-TdCf(WRf) 


Data Stable prior to WR 1 


190* 




80* 




25* 






















31 


TwWR 


WR Pulse Width 


360* 


— 


220* 


— 


135* 


— 




32 


TdCf(WRr) 


Clock 1 to WR I Delay 


— 


100 


— 


80 


— 


70 




33 


TdD(WRf) 


Data Stable prior to WR 1 


20* 


— 


-10* 


— 


-55* 


— 




34 

35- 

36 


TdCr(WRf) 

-TdWRr(D) 

TdCf(HALT) 


Clock t to WR 1 Delay 




80 




65 




60 








300 




300 








Clock I to HALT t or 1 


260 




37 
38 


TwNMI 
TsBUSREQ(Cr) 


NMl Pulse Width 


80 
80 


- 


80 
50 


- 


70 
50 


- 




BUSREQ Setup Time to Clock t 


— 



N 

00 

o 
o 

■0 

a 



'For clock periods other than the minimums shown in the table, 
calculate parameters using the expressions in the table on the 
following page. 
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AC 

Charac- 
teristics 

(Continued) 



Number Symbol 



Parameter 



Z80CPU 
Min Max 
(ns) (ns) 



Z80A CPU 
Min Max 
(ns) (ns) 



BUSREQ Hold Time after Clock t 



39 ThBUSREQ(Cr) 

40 — TdCr(BUSACKf) -Clock t to BUSACK J Delay 

41 TdCf(BUSACKr) 

42 TdCr(Dz) 

43 TdCr(CTz) 



44 


TdCr(Az) 


45- 






46 


TsRESET(Cr) 


47 


ThRESET(Cr) 


48 


TsINTf(Cr) 


49 


ThlNTr(Cr) 


50- 


-TdMlf(IORQf) 


51 


TdCf(IORQf) 


52 


TdCf(IORQr) 


53 


TdCf(D) 



Clock 1 to BUSACK t Delay 

Clock I to Data Float Delay 

Clock t t o Cont r ol Ou tputs Float 
Delay (MREQ, IORQ, RD, 
and WR) 

Clock t to Address Float Delay 

■ A ddress Stable after MREQ t , 

IORQ t, RD t, and WR t 



RESET to Clock t Setup Time 



160*- 



90 



RESET to Clock t Hold Time 
INT to Clock t Setup Time 
INT to Clock t Hold Time 



•Ml 1 to IORQ I Delay • 



Clock I to IORQ 1 Delay 



Clock t to IORQ t Delay 
Clock 1 to Data Valid Delay 



■120 
110 
90 
110 

110 



— 
80 - 

— 
920* 



110 

100 
230 



— 
100 



— 100 

— 90 

— 80 

— 90 
•80* 



60 — 

— 
80 - 

— 
•565* 



— 85 

— 85 

— 150 



'For clock periods other than the minimums shown in the table, 
calculate parameters using the following expressions. Calculated 
values above assumed TrC = TfC = 20 ns. 



Footnotes to AC Characteristics 



Z80B CPU 
Min Max 
(ns) (ns) 



— 
90 

- 90 

— 80 

- 70 

— 80 
■35* 



60 — 

— 
70 — 

— 
■365* 

— 70 

— 70 

— 130 



Number Symbol 



Z80 



Z80A 



Z80B 



1 TcC 

2 TwCh 

7 TdA(MREQf)- 

10 TwMREQh 

11 TwMREQl 
26 TdA(IORQf) 
29 TdD(WRf) 

31 TwWR 

33 TdD(WRf) 
35 TdWRr(D) 
45 TdCTr(A) 
50 TdMlf(IORQf) 



TwCh + TwCl + TrC + TfC 

Although static by design, 
TwCh of greater than 200 ^s 
is not guaranteed 

■ TwCh + TfC - 75 

TwCh + TfC - 30 

TcC - 40 
TcC - 80 
TcC - 210 

■ TcC - 40 



TwCl + TrC - 180 
TwCl + TrC - 80 
TwCl + TrC - 40 
2TcC + TwCh + TfC - 80 



TwCh + TwCl + TrC +TfC 

Although static by design, 
TwCh of greater than 200 /is 
is not guaranteed 

TwCh + TfC - 65 

TwCh + TfC - 20 

TcC - 30 

TcC - 70 

TcC - 170 

TcC - 30 



TwCl + TrC - 140 
TwCl + TrC - 70 
TwCl + TrC - 50 
2TcC + TwCh + TfC - 65 



TwCh + TwCl. + TrC + TfC 

Although static by design, 
TwCh of greater than 200 /is 
is not guaranteed 

• TwCh + TfC - 50 

TwCh + TfC - 20 

TcC - 30 
TcC - 55 
TcC - 140 

• TcC - 30 



TwCl + TrC - 140 
TwCl + TrC - 55 
TwCl + TrC - 50 
2TcC + TwCh + TfC - 50 



AC Test Conditions: Voh = 2.0 V 

VjH = 2.0 V Vql = 0.8 V 

V IL = 0.8 V FLOAT = ±0.5 V 

VlHC = V C C -0.6 V 
ViLC = 0.45 V 



24 



APPENDIX F.... FLOPPY ERROR CODE 
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Table 6 STATUS REGISTER SUMMARY 





ALL TYPE 1 


READ 


READ 


READ 


WRITE 


WRITE 


BIT 


COMMANDS 


ADDRESS 


SECTOR 


TRACK 


SECTOR 


TRACK 


S7 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


NOT READY 


S6 


WRITE 
PROTECT 











WRITE 
PROTECT 


WRITE 
PROTECT 


S5 


HEAD LOADED 





RECORD TYPE 





WRITE FAULT 


WRITE FAULT 


S4 


SEEK ERROR 


RNF 


RNF 





RNF 





S3 


CRC ERROR 


CRC ERROR 


CRC ERROR 





CRC ERROR 





S2 


TRACK 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


LOST DATA 


S1 


INDEX 


DRQ 


DRQ 


DRQ 


DRQ 


DRQ 


SO 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 


BUSY 



STATUS FOR TYPE I COMMANDS 



BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and logically 'ored' with MR. 


S6 PROTECTED 


When set, indicates Write Protect is activated. This bit is an inverted copy of WRPT 
input. 


S5 HEAD LOADED 


When set, it indicates the head is loaded and engaged. This bit is a logical "and" of 
HLD and HLT signals. 


S4 SEEK ERROR 


When set, the desired track was not verified. This bit is reset to when updated. 


S3 CRC ERROR 


CRC encountered in ID field. 


S2 TRACK 00 


When set, indicates Read/Write head is positioned to Track 0. This bit is an inverted 
copy of the TROO input. 


SI INDEX 


When set, indicates index mark detected from drive. This bit is an inverted copy of the 
IP input. 


SO BUSY 


When set command is in progress. When reset no command is in progress. 




STATUS FOR TYPE II AND III COMMANDS 



BIT NAME 


MEANING 


S7 NOT READY 


This bit when set indicates the drive is not ready. When reset, it indicates that the drive 
is ready. This bit is an inverted copy of the Ready input and 'ored' with MR. The Type II 
and III Commands will not execute unless the drive is ready. 


S6 WRITE PROTECT 


On Read Record: Not Used. On Read Track: Not Used. On any Write: It indicates a 
Write Protect. This bit is reset when updated. 


S5 RECORD TYPE/ 
WRITE FAULT 


On Read Record: It indicates the record-type code from data field address mark. 
1 = Deleted Data Mark. = Data Mark. On any Write: It indicates a Write Fault. This bit 
is reset when updated. 


S4 RECORD NOT 
FOUND (RNF) 


When set, it indicates that the desired track, sector, or side were not found. This bit is 
reset when updated. 


S3 CRC ERROR 


If S4 is set, an error is found in one or more ID fields; otherwise it indicates error in 
data field. This bit is reset when updated. 


S2 LOST DATA 


When set, it indicates the computer did not respond to DRQ in one byte time. This bit is 
reset to zero when updated. 


S1 DATA REQUEST 


This bit is a copy of the DRQ output. When set, it indicates the DR is full on a Read 
Operation or the DR is empty on a Write operation. This bit is reset to zero when up- 
dated. 


SO BUSY 


When set, command is under execution. When reset, no command is under execution. 
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FD179XA-02 CERAMIC PACKAGE 



FD179XB-02 PLASTIC PACKAGE 



This is • preliminary specification with tentative device parameters and may be subject to change after final product characterization Is 
completed. 

Information furnished by Western Digital Corporation is believed to be accurate and reliable. However, no responsfbWty is assumed by 
Western Digital Corporation for its use; nor any infringements of patents or other rights of third parties which may result from its use. No 
Kcense is granted by implication or otherwise under any patent or patent rights of Western Digital Corporation. Western Digital Corporation 
reserves the right to change said circuitry at anytime without notice. 



WESTERN DIGITAL 3128 REDHILL AVENUE. BOX 2180 

e o * » o * * r , o » NEWPORT BEACH, CA 92663 (714) 557-3550.TWX 910-595-1139 



354 



- ADVANCED, 
DIGITAL 

CORPORATION. 



WARRANTY NOTICE 



Advanced Digital Corporation now requires a Return Authorization 
Number for the return of any equipment for repair or credit. This 
number will be issued by the Customer Support Department. Any 
equipment received without the Return Authorization Number clearly 
marked on the outside of the package may be subject to significant 
delays in the repair process. 

Return Authorization Numbers are active for 30 days after they are 
issued. If the equipment specified in the Return Authorization is 
not received by Advanced Digital within this 30 day period signi- 
ficant delays in handling the repair may be incurred. 

If the equipment must be returned a second time, a new Return 
Authorization Number must be issued. Reuse of Return Authorization 
Numbers may result in delays in processing returns. 

Effective November 1, 1981, repair of all kit and nonwarranty 
boards will be $70.00. This fee is subject to change without 
notice . 

Returns for credit will be subject to a 15% restocking charge. If 
material for credit was purchased through a dealer, Advanced Digital 
cannot issue a credit. Adjustment must be handled through the dealer. 
Other credit returns should have reference to the original invoice 
number. 

If you have any questions regarding special handling, packaging of 
the equipment, or procedures for returning equipment, please contact 
the Advanced Digital Corporation. 



The warranty on the super quad is one year from the date of purchase. 



TECHNICAL APPLICATION NOTES FOR THE SUPER QUAD SINGLE BOARD COMPUTER. 

In case of problems with the SUPER QUAD? these are two thing a customer 
may do: 

1. send the product back for warranty service (turn around time is 1 day) 

2. follow thw following notes and then if there are still no results do 
the first stepl 

1. If the board is totaly dead and won't communicate with the CRT, then 
do the following: 

a. check you power supply for 5,+ ,-12 volts. 

b. check pins 1,3,17 of the U53 (BR1941) baud^rate gen. for step type 
pulses. (if you do not see any thing on these~ pins then replace the 
BR1941 chip) 



c. Check your PS NET/I the serial port adapter cable for possible 
loss of + or - 12 volts or the 1488 chip. 

d. check pin 3 of Ull(741sll). there should be a positive going 
signal (about 5 volts) and when you press RESET you should see that 
pulse going to ZERO voltage. 

e. If the step d is OK then you have a problem with either on of the 
a or b or c . 

f . check the 4MHZ clock signal going to pin 6 of the CPU. 

2. If there is a problem with the floppy disk controller part only and 
you think that the phase lock loop needs to be adjusted, then follow 
the folowing steps: 

a. This is done with the help of a dual trace scope. 

b. put one channel on the 4MHZ signal (PIN 6 of the cpu chip) 

put the other channel on pin 7 of the U27(74sl24) and by tweeking 
the R26 (pot) those two signals are supposed to lock. 

c. the above procedure is only recomended to engineeres or technicians 
with experience of doing such things before. 

3. Make sure the board is being properly cooled by a fan. 

4. The power consumption of the board is: 
+8v 1.8 amps max. 

+ 16 .4 amps max. 

-16 .2 amps max. 

5. To ensure the proper operation of your floppy disk drives, make 
sure to put the termination resistor at the end of the cable. 

6. Refer to the softare manual for software problems. 
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\pplication notes to run TURBO-DOS operating system: 

If you have one of the early revisions of the SUPERQUAD check the following 

1. pin 13 of the CTC should be hooked to +5V. 

2. R17 should be hooked to +5. 

3. for double sided drives, there should be a jumper from j3 connector 
to PIO bit3(PIO-29) 

4. IE3 lin2 (PIO-22) should goto ul8-9, on some older tev. boards its 
also going to pin 12 of ul4. the place to cut would be on top of uO 
right above pin 20 there is a pad hole; the etch going north should be 
cut, then install a jumper from ul4-12 to ul5-6 
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application notes on how to interface the Measurement Systems Memory (DMB6400) 

xo the SUPERQUAD. 

ON DMB6400 SET SWITCHES AS FOLLOWS: 
(TOGLE SWITCH... UP MEANS PRESS TO THE TOP DOWN) 
Sl-1 DOWN,Sl-2 D0WN.S1-3 DOWN, Sl-4 DOWN 

S2-l,2,4,5 UP S3-l,2 UP— S4-l,4 DOWN S5-1 , 2 , 3 ,4 , 5 , 6 ,8 UP 

HEADER 1 SHOULD BE WIRED AS: PIN 1 TO 16,3 TO 9,7 TO 11,8 TO 10. 
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SUPER NET MODIFICATION SHEET 



To run the SUPER Quad (Advanced Digital Corportion's S-100 single 
board computer) with the BSR 64/256 (PCE Systems* 256K RAM card) there 
are two modifications to be made to the SUPER §ty\t>. The first 
modification (as described below) is to buffer the Z-80 refresh 
signal, and bring it to pin 66 of the S-100" bus (see figure 1). 



Jl 



RFSH 



1) Solder a wire from JJ50, pin 28 
(Z-80) to U43, pin 14 (8T97). 2) 
Solder a wire from U43, pin 13 
(8T97) to pin 66 of the S-100 bus. 



Th"e "secol^ ^o^iTicatfcTrr heeds - td~be 
done so that the RAM card can sense 
when the Z80 is in a wait sta te . 
This is done by cutting the RAM 

RFSH and FDC WAIT signals on the 

SUPER fyuM away from the inputs of HOLD 

U56, and ANDING them and tying the 

result to PRDY of the S-100 bus XRDY 

(see figure 2) . Because PRDY may be PRDY 

driven by a number of different 

cards, an open Collector device is 

needed. For this purpose a 7409 is 

added to the board, as described n 

below, at SPARE location U57. (2-D5) E - RtbH_j± 



U43 
13 <^ j 14 28 



8T97 




(4-C7) ^ DC WAIT 1 



Figure 2 

1) Solder a 14 pin socket in location U57 for a 7409. 2) Solder a 
wire from RM6, pin 2 to U57, pin 1. 3) Solder a wire from the plated 

* 

through hole located under U55 between pins 13 & 14, to U57, pin X- 
4) Solder a wire from U57, pin 3 to U56, 



RM6 



pin 4. 5) Cut two traces located on 
component side of board between U56 and 
RM6 (see figure 3). 6) Install a 7409 in CUTS 
U57. U56 




i 



Ic k 



' /' '~ > : / 



^U, 



^7 £2> 



Figure 3 

/ 
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Parts list 



SUPER NET Parts list 



Item ] 


[ Part Number ] 


[ Location on board ] 


[ Quantity 


1. ] 


: 74LS00 3 


[ U-13 ] 


L 1 


2. ] 


C 74S04 ] 


[ U-6 ] 


C 1 


3. ] 


[ 74LS04 ] 


[ U-18,U-34 ] 


[ 2 


4. ] 


[ 7406 ] 


L U-32 ] 


[ 1 


5. 3 


[ 7407 ] 


L ' U-l ] 


[ 1 


6. ] 


L 74LS10 ] 


L U-41 ] 


L 1 


7. ] 


[ 74LS11 ] 


[ U-ll ] 


[ 1 


8. ] 


[ 74LS13 ] 


L U-47,U-56 ] 


L 2 


9. ] 


[ 74LS14 , ] 


[ U-2 ] 


[ 1 


10. ] 


[ 74LS27 ] 


L U-35 ] 


[ 1 


11. ] 


[ 74LS32 ] 


[ U-42,U-22 ] 


[ 2 


12. ] 


[ 7438 ] 


L U-14 ] 


[ 1 


13. ] 


[ 74LS74 ] 


[ U-33,U-40 ] 


: 2 


14. ] 


[ 74LS123 ] 


[ U-3,U-4 ] 


[ 2 


15. ] 


[ 74S124 ] 


[ U-27 ] 


L 1 


16. 3 


L 74LS132 ] 


[ U-16,U-39,U-46 ] 


[ 3 


17. ] 


t 74LS138 ] 


l U-21 r U-36 ] 


2 


18. 1 


[ 74LS139 ] 


[ U-5 ] 


[ 1 


19. ] 


[ 74LS153 ] 


l U-28 1 


: l 


20. : 


[ 74LS175 ] 


[ U-10 ] 


[ l 


21. ] 


[ 74LS240 ] 


[ U-59,U-24 ] 


: 2 


22. 


L 74S240 ] 


L U-68,U-69 1 


[ 2 


23. ] 


L 74LS244 ] 


[ U-8 1 


: l 


24. 


[ 74LS245 1 


[ U-44,U-51 ] 


[ 2 


25. ] 


[ 74LS273 ] 


[ U-17 ] 


: l 


26. 


[ 74S287(PR0M) 1 


[ U-49 ] 


t l 


27. ■] 


L 74LS373 ] 


[ U-25,U-30 ] 


; 2 


28. 


L 74LS374 ] 


C U-23 ] 


l l 


29. ] 


[ 74LS393 ] 


[ U-12,U-7 ] 


: 2 


30. 


[ MB4164-20 ] 


[ U-60 THRU U-67 3 


[ 8 


31. ] 


[ Z-80A CPU 1 


[ U-50 ] 


l 


32. 


[ Z-80A PIO ] 


[ U-9 ] 


[ l 


33. ] 


[ Z-80A DART(SIO)] 


[ U-52 ] 


: l 


34. 


[ Z-80A CTC ] 


[ U-37 1 


[ l 


35. ] 


L WD-1793(8877) ] 


[ U-26 ] 


: l 


36. ] 


[ WD-1691 ] 


[ U-19 1 


[ l 


37. ] 


[ WD-2143 1 


[ U-20 ] 


l 


38. 


[ BR-1941 1 


L U-53 3 


[ l 


39. ] 


L TTLDM-100 ] 


[ U-54 ] 


l 


40. 


L 2716 EPROM 1 


[ U-29 3 


l l 


41. ] 


[ 8T97 ] 


[ U-43 ] 


l 


42. 


L 8T98 ] 


[ U-55,U-15 3 


[ 2 


43. 1 


[ 14 PIN HEADER ] 


[ U-31 ] 


: l 


44. 


[ LK323K VOLT. ] 


[ VR1 ] 


[ l 


45. 1 


L 8.000 MHZ XTAL .] 


[ Yl ] 


: l 


46. 


[ 5.06 MHZ XTAL ] 


[ Y2 ] 


t l 


47. 1 


I 16 PIN SWITCH ] 


[ SW1 ] 


: l 


48. 


I 2N2222 TRANS. 1 


t Q1,Q2,Q4 ] 


[ 3 


49. 1 


L 2N39G6 TRANS. 1 


[ Q3 ] 


: l 



■ t*. I 



50. 

51. 
52. 
53. 
54. 
55. 
56. 
57. 
58. 
59. 
60. 
61. 
62. 
63. 
64. 
65. 



I 78L12 3 


l Q5 1 


[ 1 


I 220 MH CHOKE 1 


L L1,L2 ] 


[ 2 


I 4.7K SIP 1 


[ RM1,RM3,RM7 ] 


[ 3 


I 10K SIP ] 


L RM2,RM5 ] 


[ 2 


I 33 OHM SIP ] 


[ RM6 ] 


L 1 


I 220/330 SIP 1 


[ RM4 ] 


[ 1 


I 33 OHM DIP ] 


[ RM8 ] 


L 1 


I 1N914 DIODE ] 


[ CR2 ] 


[ 1 


I 5.1 V ZENER 1 


[ CR1 ] 


[ 1 


I 100 MF CAP 


[ C2 ] 


L 1 


I .1 MF CAP ] 




L 21 


I 4.7 MF CAP 


L ' C6,C3,C10,C27,C28: 


[ 8 


I 10K POT ] 


[ R27 r R28 1 


[ 2 


I 14 PIN HEADER 


L *J4 r J5 


[ 2 


I 50 PIN HEADER 3 


[ J3 ] 


[ 1 


I 40 PIN HEADER 


L J2 


[ 1 



IZ, 2 



13.0 Schematic diagram 
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